C语言易错点整理

前言:

本文涵盖了博主在平常写C语言题目时经常犯的一些错误,在这里帮大家整理出来,一些易错点会帮大家标识出来,希望大家看完这篇文章后有所得,引以为戒~

一、

题目:

解答:

首先在这个程序中有两个x,y,一个是在主函数中定义的局部变量,另一个是全局变量。

而在swap函数中将两个值进行了交换,因为在主函数中定义的变量只在主函数中有效,因为主函数也是一个函数,它与其他函数是平行关系!所以swap函数是将在主函数外部的全局变量进行了交换。

其次在主函数中我们需要打印x,y,根据输出语句,局部变量优先的原则,所以最后的结果就是3,8

易错点:

  1. 不知道在主函数中定义的变量只在主函数中有效
  2. 不知道在输出语句中,局部变量优先的原则

二、

题目:

解答:

本题选择B,

\ddd ddd表示13个八进制数(d用八进制数表示才合法

\xhh hh表示12位十六进制数 (h用十六进制数表示才合法

原因是 '\8' 表示错误,因为转义字符\后面只要跟了十进制的数字,就是表示八进制数,但是八进制表示的范围是0~7, 所以'\8' 表示错误。

易错点:

不知道常见转义字符的形式,\后面直接跟数字,表示是一个八进制数,但表示形式必须要用0~7;同理/后面跟x表示是一个十六进制数,表示形式也必须使用十六进制~

小总结:

以后看到字符表示中有\在前面就表示它是一个转义字符,看\后面的字母来判断这是什么样的字符。

三、

题目:

解答:

本题要求根据输入的日期,计算是这一年的第几天。

我们可以每一月的月数存放在一个数组中,根据输入的月份for循环累加,特殊情况判断闰年的情况

源码:

int main()
{int year = 0;int month = 0;int day = 0;int sum = 0;int num[12] = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};//直接用数组创建,比switch语句简洁了不少while(scanf("%d %d %d",&year,&month,&day) != EOF){if(year % 400 == 0 || (year % 4 == 0 && year % 100 != 0))num[1] = 29;//累加月份,这种事就让电脑干for(int i = 0;i < month-1;i++){sum += num[i];}sum += day;printf("%d\n",sum);}return 0;
}

四、

题目:

 解答:

\\表示一个 '\' 字符,\123表示一个八进制数,\t 表示水平制表。所以最后的结果是12.

易错点:

 \\ \' \'' \ddd \xhh

以上这几个比较容易出错,需要多加注意

五、

题目:

如下函数f(1)的值是多少

解答:

首先明确i是一个局部变量,此题注意静态局部变量的使用,改变局部变量的销毁时期

static改变了i的生命周期,第一次调用函数:i初值是1,递归第二次调用函数时,i还是第一次那个变量,值已经变成了2,再一次调用函数时i就是3,以此类推

易错点:

不清楚静态局部变量的意义。静态局部变量存储在静态存储区,当静态局部变量离开作用域后,并没有被销毁,被修饰变量的值没有改变,比如本题的i变量的值不会改变,会一直++

六、

题目:

解答:

本题关键在于知道规律后,能够找到第 n 个数据立方的起始奇数,

但我觉得最重要的是如何将一个整型表达式转化为字符串类型

这里需要引用一个新函数sprintf函数,它可以直接将整型类型转换为字符串类型。

sprintf函数的用法

格式化字符串但是不用于打印而是放到一个buf中,所以需要提前创建一个char类型的数组。

可以直接将整型全部转换为字符串类型:

int main()
{char buf[100];int a = 100;int b = 20;//sprintf(buf, "%d", a);sprintf(buf, "%d+%d", a, b);printf("%s", buf);return 0;
}

 可以部分转换,以本题举例:

int main()
{
int m;
while(~scanf("%d", &m)){
int start = m * (m - 1) + 1;//找到对应m^3的起始奇数
char buf[10240] = {0};
//sprintf(buf, format, ...) 与printf用法类似,格式化字符串但是不用于打印而是放到一个buf中
sprintf(buf, "%d", start);//先将起始奇数转换成为字符串存入buf中
for (int i = 1; i < m; i++) {
//然后将紧随随后的m-1个奇数数字转换为字符串,按照指定格式放入buf中
//%s+%d, 要求先有一个字符串,然后是+符号,然后是个数字的格式,对应是buf原先的数据,和奇数
sprintf(buf, "%s+%d", buf, start+=2);
}
printf("%s\n", buf);
}
return 0;
}

七、

题目:

若运行以下程序时,从键盘输入 ADescriptor< 回车 > ,则下面程序的运行结果

易错点:

  • getchar()读取所有字符,所以最后的回车也会被读入
  • 代码switch语句中没有break,则每次找到入口进入后,顺序执行到代码块结束为止

八、

题目:

以下程序的功能:

 

解答:

一个字母对应的大写和小写之间的 ASCII 码值相差 32 ,而且 小写的ASCII码值大于大写 的。所以题中 'e' 'E' 之间的 ASCII 码值相差 32( ch[j]+'e'-'E' 相当于 ch[j]+32 )。可以直接+32

总结:

一个字母从大写转化为小写就是在它自身上 +32 ,小写转大写则是 -32。(相反)

九、

题目:

数字在升序数组中出现的次数_牛客题霸_牛客网 (nowcoder.com)

注意题目中要求时间复杂度在O(logN),并且还是非降序,很明显这题要使用二分思想。

思路:

采用遍历也能搞定,不过数组为非降序,采用 二分查找 的思想最优,先二分找到最左边的数字位置,再二分查找最右边的数字位置,两个位置相减+1 就是长度了。
  • 中间比找的值大:则要找的数字肯定在右边, left = mid + 1;
  • 中间比找的值小:则要找的数字肯定在左边, right = mid - 1
  • 中间值与找的值相同:
找的最左边数字:如果 mid 就是 left ,则返回 mid 就行,否则重置 right=mid-1 ,把中心不断向左偏移
找的最右边数字:如果 mid 就是 right ,则返回 mid 就行,否则重置 left=mid+1 ,把中心不断向右偏移

源码:

int GetNumberOfK(int* nums, int numsLen, int k ) {// write code here//先二分找到最左边的数字位置,再二分查找最右边的数字位置,两个位置相减+1就是长度int cnt = 0;int left = 0;int right = numsLen - 1;int mid;while(left <= right) {mid = (left+right)/2;//每次循环都需要放在中间if(nums[mid] > k){right = mid-1;}else if (nums[mid] < k){left = mid+1;}else {int ret = mid;while(nums[ret] == k){ret--;}left = ret+1;ret = mid;while(nums[ret] == k){ret++;}right = ret-1;return right - left + 1;}}return 0;
}

十、

题目:

解答:

|| 操作符表示只要有一个为真就是真,刚开始0<5,执行i++,当i = 1时,

逻辑或操作符前表达式为真,后表达式不计算!所以前表达式i = 1,后面的i++,就不计算,因此i恒为1,所以是死循环!

易错点:

不知道逻辑或操作符当前表达式为真,后表达式不计算这个特点

十一、

题目:

c 语言中,一个函数不写返回值类型,默认的返回类型是?

解答:

一个函数不写返回值类型, 默认的返回类型是int ,但不提倡这么做。

十二、

题目:

解答:

字符数组定义的两种方式:

arr1和arr2都是合法的,arr3报错是字符数组初始化需要带括号的初始化表达式

十三、

题目:

169. 多数元素​​​​​​z

解答:

注意本题的要求是时间复杂度在O(N),所以不能简单的使用暴力双层循环的办法。

采用互拼的思想。 

一个数组中有一个数字出现次数大于 n/2 ,从第 0 个字符开始,假设它就是最多的那个数字,遇到相同的数字则计数 +1 ,遇到不同的则计数 -1 ,其实就是互相消耗,等到计数为 0 的时候,表示本次互拼完毕,从下一个字符重 新开始互拼, 但是归根结底出现次数大于 n/2 的这个数字数量更多,因此也是最后保留的字符

源码:

int majorityElement(int* nums, int numsSize)
{//利用互拼的思想int n = nums[0];int cnt = 1;for(int i = 1;i<numsSize;i++){if(n == nums[i])cnt++;elsecnt--;if(cnt == 0)n = nums[i+1];}return n;
}

十四、

题目:

解答:

逗号表达式是 从前到后依次计算子表达式,而其结果是最后一项的值 ,本题的括号无用,所以最后的结果就是25.

十五、

题目:

238. 除自身以外数组的乘积

思路:

题目中要求使用O(N)的算法进行计算,我的第一想法是将所有数据相乘,遍历一遍数组元素,然后分别相除,但题目中有要求不能使用除法,但是除法与乘法互相转换的。

我们可以将乘积分为两次进行,第一次先将每个位置左边的数据乘积计算出来放到返回数组中,后边第二次循环将对应位置右边的数据乘积计算出来与返回数组对应位置的左半边乘积相乘得到结果。

源码:

int* productExceptSelf(int* nums, int numsSize, int* returnSize)
{int left[numsSize];int right[numsSize];*returnSize = numsSize;int* arr = (int*)malloc(sizeof(int)*(*returnSize));//分别计算每个元素左边的乘积left[0] = 1;int ret = 1;for(int i = 1;i<numsSize;i++){ret*=nums[i-1];left[i] =  ret;}//分别计算每个元素右边的乘积ret = 1;right[numsSize-1] = 1;for(int i = numsSize-2;i>-1;i--){ret*=nums[i+1];right[i] = ret;}for(int i = 0;i<numsSize;i++){printf("%d ",left[i]);}printf("\n");for(int i = 0;i<numsSize;i++){printf("%d ",right[i]);}//最后计算两者相乘for(int i = 0;i<numsSize;i++){arr[i] = left[i] * right[i];}return arr;
}

十六、

题目:

448. 找到所有数组中消失的数字

 题目中要求时间复杂度O(N),空间复杂度是O(1)。

思路:

以数组元素的 绝对值 作为下标,(因为前面有可能将后面的数值变为负数,负数访问数组下标会越界)。
将对应位置的数据置为负数,比如 0 号位置是 3 ,则把 3 号位置的数据重置为负值,等到数组遍历重置完毕,只有缺失的这个数字对应的位置保留正数,其他出现过的数字位置都会是负数, 要注意不要重复设置负数,因为负负得正。
为什么会想到这个思路?
因为数组的内容和数组的下标相对应

TIP:

 ++ 的优先级要比 解引用* 操作符优先级高,为了避免这个问题可以直接用括号,或者*returnsize+=1。

源码:

int* findDisappearedNumbers(int* nums, int numsSize, int* returnSize){*returnSize = 0;int* arr = (int*)malloc(sizeof(int)*numsSize);//注意遍历到后面的值可能是负数,下标访问会越界,所以需要绝对值函数for(int  i =0;i<numsSize;i++){int ret = abs(nums[i])-1;if(nums[ret] < 0)continue;else{nums[ret] = -nums[ret];}}for(int i = 0;i<numsSize;i++){if(nums[i] > 0){arr[*returnSize] = i+1;// ++ 的优先级要比 解引用* 操作符优先级高//*returnSize++;  error!*returnSize+=1;}}return arr;
}

十七、

题目:

 解答:

一般表达式的运算是在运行时执行的,而 sizeof 是一个编译阶段就执行的运算符,在其内的任何运算 都不执行 ,只推测出其中表达式结果的类型求其大小,故前后i 的值不变。

易错点:

不知道sizeof内部的任何运算都不执行。

十八、

题目:

解答:

0'<=c<='9' 并非判断 x 大于等于字符 0, 小于等于字符 9 ,而是 先执行'0'<=c ,使用这个表达式的结果再和 '9' 比较, '0' ASCII 码值是48 'A' ASCII 码值是 '65' ,故 '0'<c 是真值 1 1 无疑是小于字符 '9' 的,最终是真

易错点:

0'<=c<='9' 这个表达式并不是真正数学意义上的比较,在计算机语言中应该从右到左一一进行计算。

十九、

题目:

思路一:

将这个正数取余取出每一位,然后将每一位整型+'0',变为字符型即可

源码:

int main()
{long long n = 0;scanf("%lld",&n);char* arr = (char*)malloc(sizeof(char)*1000);int num = 0;if(n == 0)printf("%d",n);while(n){arr[num++] = n%10 + '0';n/=10;}for(int i = 0;i<num;i++){printf("%c",arr[i]);}return 0;
}

 思路二:

利用sprintf函数,不需要一个一个的进行取余,直接将整个整型的数字转换为字符型。

源码:

int main()
{int n = 0;scanf("%d",&n);char buf[1000];sprintf(buf,"%d",n);int len = strlen(buf);for(int i = len-1;i>-1;i--){printf("%c",buf[i]);}return 0;
}

二十、

题目:

单词倒排_牛客题霸_牛客网 (nowcoder.com)

思路:

定义一个字符指针数组,用于保存每个单词的 起始字符地址 ,接下来将 非字母字符全部替换成为字符串结尾标志 ,则单词字符字母遇到结尾就结束了,相当于把一个字符串以非字母字符进行切割成为了多个字符串,最终对字符指针数组进行逆序打印每个单词即可。

源码:

int main()
{char arr[10005];char* ret[10005];//记录每一个单词的首元素地址int cnt = 0;//记录首元素地址的个数gets(arr);int len = strlen(arr);//单独判断首元素if((arr[0]>='a' && arr[0]<='z') ||(arr[0] >= 'A' && arr[0]<='Z')){ret[cnt++] = &arr[0];}else {arr[0] = '\0';}for(int i = 1;i<len;i++){if((arr[i]>='a' && arr[i]<='z') ||(arr[i] >= 'A' && arr[i]<='Z')){if((arr[i-1]>='a' && arr[i-1]<='z') || (arr[i-1] >= 'A' && arr[i-1]<='Z'))continue;else{ret[cnt++] = &arr[i];//将单词的首元素地址进行存储}}else{arr[i] = '\0';}}for(int i = cnt-1;i>-1;i--){printf("%s ",ret[i]);}return 0;
}

二十一、

题目:

解答:

x=x|(x+1);的作用是每次循环把x的二进制中从右往左数的最后一位0变成1 ,直到变成
全1的时候x+1就溢出为全0 ,循环结束

易错点:

不知道当二进制位每一位都是1,之后再进行+1结果会变成全0。

二十二、

题目

 解答:

本题首先是执行后置++,但是是后置++,实际的++操作是在本条语句的最后 然后就是*pa = *pa * 3;然后进行++

易错点:

忘记后置++的计算顺序,应该是最后再算++。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/105001.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

自己搭建Minecraft服务器并通过cpolar内网穿透实现与公网小伙伴联机我的世界

文章目录 1. Java环境搭建2.安装我的世界Minecraft服务3. 启动我的世界服务4.局域网测试连接我的世界服务器5. 安装cpolar内网穿透6. 创建隧道映射内网端口7. 测试公网远程联机8. 配置固定TCP端口地址8.1 保留一个固定tcp地址8.2 配置固定tcp地址 9. 使用固定公网地址远程联机 …

MIA文献阅读 —— 深度学习在医学图像分析中的最新进展及临床应用【2022】

目录 0 摘要1 引言2 深度学习方法概述2.1 监督式学习2.2 无监督学习2.2.1 自编码器 (Autoencoders)2.2.2 生成对抗网络(GANs)2.2.3 自监督学习 2.3. 半监督学习2.4 提高性能的策略2.4.1 注意力机制2.4.2 领域知识2.4.3 估计的不确定性 3 深度学习应用3.1 分类3.1.1 监督分类3.1…

免费清理电脑:删除垃圾文件以提升电脑性能

求助&#xff01;电脑上没有可用空间 ​“我只在电脑上存储了大约100张照片&#xff0c;为什么我的硬盘空间已满&#xff1f;电脑运行速度也变得越来越慢&#xff0c;要疯了&#xff01;现在我想安装更新的驱动程序。我可以释放磁盘空间吗&#xff1f;有免费的Windows电脑清…

免费开源使用的几款红黑网络流量工具,自动化的多功能网络侦查工具、超级关键词URL采集工具、Burpsuite被动扫描流量转发插件

免费开源使用的几款红黑网络流量工具&#xff0c;自动化的多功能网络侦查工具、超级关键词URL采集工具、Burpsuite被动扫描流量转发插件。 #################### 免责声明&#xff1a;工具本身并无好坏&#xff0c;希望大家以遵守《网络安全法》相关法律为前提来使用该工具&am…

【python】Leetcode(primer-set)

文章目录 78. 子集&#xff08;集合的所有子集&#xff09;90. 子集 II&#xff08;集合的所有子集&#xff09;792. 匹配子序列的单词数&#xff08;判断是否为子集&#xff09;500. 键盘行&#xff08;集合的交集&#xff09;409. 最长回文串&#xff08;set&#xff09; 更多…

Tomcat的安装与介绍

首先我们先了解一下什么是服务器&#xff1f;什么是服务器软件&#xff1f; 什么是服务器&#xff1f;安装了服务器软件的计算机。 什么是服务器软件&#xff1f; 服务器软件是一种运行在服务器操作系统上&#xff0c;用于接收和处理客户端请求&#xff0c;并提供相应服务和资…

微信小程序,封装身高体重选择器组件

wxml代码&#xff1a; // 微信小程序的插值语法不支持直接使用Math <wxs src"./ruler.wxs" module"math"></wxs> <view class"ruler-container"><scroll-view scroll-left"{{scrollLeft}}" enhanced"{{tru…

java八股文面试[java基础]——CGLIB动态代理与JDK动态代理

CGLIB CGLIB简介&#xff1a; 什么是CGLIB CGLIB是一个强大的、高性能的代码生成库。其被广泛应用于AOP框架&#xff08;Spring、dynaop&#xff09;中&#xff0c;用以提供方法拦截操作。Hibernate作为一个比较受欢迎的ORM框架&#xff0c;同样使用CGLIB来代理单端&#xff…

Kyligence Copilot 登陆海外,斩获 Product Hunt 日榜 TOP 2

8月14日&#xff0c;AI 数智助理 Kyligence Copilot 在全球知名科技产品平台 Product Hunt 上线&#xff0c;其以出色的产品创新实力&#xff0c;在激烈的竞争中脱颖而出&#xff0c;仅仅在 24 小时内收获了超过 400 个投票和近 200 条支持评论&#xff0c;荣登当日产品榜排名第…

PDF校对:追求文档的精准与完美

随着数字化时代的到来&#xff0c;PDF已经成为了多数机构和个人首选的文件格式&#xff0c;原因在于它的稳定性、跨平台特性以及统一的显示效果。但是&#xff0c;对于任何需要公开或正式发布的文档&#xff0c;确保其内容的准确性是至关重要的&#xff0c;这就是PDF校对显得尤…

智能化追踪与实时管理:RFID技术在流水线上的革命性应用

随着科技的不断发展&#xff0c;物联网技术已经深入到了我们生活的方方面面&#xff0c;其中&#xff0c;射频识别&#xff08;Radio Frequency Identification&#xff0c;简称RFID&#xff09;技术被广泛应用于各行各业。在流水线生产中&#xff0c;RFID技术的应用也越来越广…

Linux下的系统编程——makefile入门(四)

前言&#xff1a; 或许很多Winodws的程序员都不知道这个东西&#xff0c;因为那些Windows的IDE都为你做了这个工作&#xff0c;但我觉得要作一个好的和professional的程序员&#xff0c;makefile还是要懂。这就好像现在有这么多的HTML的编辑器&#xff0c;但如果你想成为一个专…

数据库怎么备份文件,数据库一般怎么备份

在当今的数字世界中&#xff0c;数据已经成为企业的生命线。无论是客户数据、业务数据还是内部流程&#xff0c;都需要通过数据库进行存储和管理。然而&#xff0c;数据的安全性和完整性也成为企业面临的一大挑战。在这种情况下&#xff0c;数据库备份尤为重要。那么&#xff0…

FPGA解析串口指令控制spi flash完成连续写、读、擦除数据

前言 最近在收拾抽屉时找到一个某宝的spi flash模块&#xff0c;如下图所示&#xff0c;我就想用能不能串口来读写flash&#xff0c;大致过程就是&#xff0c;串口向fpga发送一条指令&#xff0c;fpga解析出指令控制flah&#xff0c;这个指令协议目前就是&#xff1a; 55 AA …

【Java架构-包管理工具】-Maven基础(一)

本文摘要 Maven作为Java后端使用频率非常高的一款依赖管理工具&#xff0c;在此咱们由浅入深&#xff0c;分三篇文章&#xff08;Maven基础、Maven进阶、私服搭建&#xff09;来深入学习Maven&#xff0c;此篇为开篇主要介绍Maven概念、模型、安装配置、基本命令 文章目录 本文…

微信开发之一键创建微信群聊的技术实现

创建微信群 本接口为敏感接口&#xff0c;请查阅调用规范手册创建后&#xff0c;手机上不会显示该群&#xff0c;往该群主动发条消息手机即可显示。 请求URL&#xff1a; http://域名地址/createChatroom 请求方式&#xff1a; POST 请求头Headers&#xff1a; Content-T…

LeetCode——二叉树篇(八)

刷题顺序及思路来源于代码随想录&#xff0c;网站地址&#xff1a;https://programmercarl.com 目录 236. 二叉树的最近公共祖先 235. 二叉搜索树的最近公共祖 迭代 递归 701. 二叉搜索树中的插入操作 450. 删除二叉搜索树中的节点 236. 二叉树的最近公共祖先 给定一个二…

睿趣科技:抖音开网店要怎么找货源

在当今数字化的时代&#xff0c;电商平台的兴起为越来越多的人提供了开设网店的机会&#xff0c;而抖音作为一个充满活力的短视频平台&#xff0c;也为创业者提供了广阔的发展空间。然而&#xff0c;对于许多初次涉足电商领域的人来说&#xff0c;找到合适的货源却是一个重要的…

无涯教程-PHP - 全局变量函数

全局变量 与局部变量相反,可以在程序的任何部分访问全局变量。通过将关键字 GLOBAL 放置在应被识别为全局变量的前面,可以很方便地实现这一目标。 <?php$somevar15;function addit() {GLOBAL $somevar;$somevar;print "Somevar is $somevar";}addit(); ?> …

全球纳米烧结银市场年复合增长率为6.5%!

烧结银简单来讲是指经过低温烧结技术将纳米银粉&#xff08;平均粒径<0.1μm(100nm)&#xff09;印刷在承印物上&#xff0c;使之成为具有传导电流和排除积累静电荷能力的银浆&#xff0c;其由导电填料——银粉、粘合剂、溶剂及改善性能的微量添加剂组成&#xff0c;使用低熔…