计算机等级C语言上机考试改错题分类总结改错题总的出错分为两大类:语法出错和逻辑出错,此类题目是比较简单的题型,因此也是最容易把握的知识点。
注意:错误都是出现在/**********fo un d**********/下面的这一行。
只是下面的这一行,其他行都没有错误。
不能修改其他行。
做题方法:1•首先拿到题目,先将题目详细看看,看清题目对做题时很有帮助的,特别是一些逻辑性较强的题目很有用。
有的同学可能会觉得题目太难了不想去读,其实在做改错题目时即便你不会也能把题目做对。
2 •按照以下的步骤解决题目中的错误的内容,对应着修改。
修改完之后保存即可。
1•关键字出错:在二级C语言考试中仅仅考查学生对基本的关键字掌握情况,比如:整型就是int不是Int,知识点简单。
2•格式出错:在考试中主要考查学生细心的程度,最喜欢考简单的知识点。
(1)少分号:考查的知识点:分号是语句结束的标志。
(2)for语句的格式:for(;;)中间用分号隔开不是用逗号隔开。
(3)if语句的格式:if(表达式),if后面必须加上小括号。
(4)命令行格式出错:如include命令少了#,正确的形式应该是#include “stdio.h” ;(5)常用函数格式:A •函数名后面一定是花括号,不能是方括号,方括号只有在数组下标中用到。
B.要同时定义两种以上不同的数据类型的时候必须在不同类型的数据中间加上分号。
C • seanf(“%d”,a[i][j]);应该改为scanf( “%d”,&a[i][j])。
考查scanf输入函数的格式。
(6)数组:A •数组下标引用时候只能用反括号。
B •二维数组中的列下标不能省略。
(7)常用符号出错:A • C语言中大于等于符号是“ >=”,但是在考试的时候可能出现将它写为“=>”B •当题目中需要比较某个字符是否是大写字母或是小写字母、数字时,必须将“与”、“或”、第1页共5页非”记住判断某个字符是否是大写字母:char ch;if(ch>=' A' && ch<=' Z' )printf( “%c” ,ch); 判断某个字符是否是小写字母:char ch;if(ch>=' a' && ch<=' z' ) printf( “%c” ,ch); 判断某个字符是否是数字:char ch;if(ch>=' O' && ch<=' 9' )printf( “%c” ,ch);判断某个数字是否能同时被5和7整除:int i=35; if(i%5==0&&i%7==0)printf( “%d” ,i);判断某个数字是否能被5或7整除:int i=35; if(i%5==0||i%7==0)printf( “%d” ,i);判断某个数字是否是偶数或奇数:int i=35;if(i%2==0) printf( “%d 是一个偶数” ,i);else printf( “%d 是一个奇数” ,i);1.使用了没有定义过的变量:这种题目可以通过编译查找出出错的地方并改之。
(1)0 (零)和o (字母欧)的区别:(2)P (大)和p (小)的区别:(3)普通变量大小写的区别:A.有的变量在定义的时候是小写但是在使用的时候是大写,或是在定义的时候是大写在使用的时候却是小写。
B .大小写没有出错,程序中直接使用了没有定义过的变量,要求学生更加细心的读题目。
2•运算符号出错:(1)C语言中除号是“ /”不是“”(2)赋值号(=)和等号(==)混淆,记住在if语句中出现赋值号(=)一般是讲它改为等号 (==)。
3•表达式的取值范围出错:当遇到计算表达式的累加或是累减时,一定用到循环来完成相应的操作。
例如:要求计算t=1-1/2*2-1/3*3- , .-1/m*m 这个表达式,在这个题目中第一空有这样的for语句:for(i=2;i<m;i++)y-=1/(i*i);从题目中不难发现i是一个变量,它的取值范围从整数2开始到m-1结束,最终计算的结果为y=1-1/2*2-1/3*3-, .-1/(m-1)*(m-1)和题目要求的不符,因此将i<m改为i<=m。
做这样的题目看两点:一看题目中的表达式,二看for语句中变量的取值范围。
4.C语言中的除法运算:这个考点同样考查表达式的相关知识。
例如:要求计算t=1-1/2怙1/3*3-, .-1/m*m这个表达式,在这个题目中第一空有这样的for语句:for(i=2;i<m;i++)y-=1/(i*i);刚才我们将了表达式的范围,现在我们考虑y-=1/(i*i);是否正确?赋值号左边问题不大,我们看看右边1/(i*i),其中i是整数,那么i*i也是整数,在C语言中1除以比它大的数时值为零。
这样和题目的要求就不相符。
记住:1/2的值为零,只有1.0/2或是1.0/2.0的值为0.5。
5•找最大值和排序问题:遇到这种题目在改错题中最容易考查的是大于( >)、小于( <)等符号的变化,当你查找出错的地方没有语法错误,也没有使用了未定义的变量时,记住这个口诀:将大于改为小于,将小于改为大于!6.函数的返回值及其参数:重点int fun (i nt x,i nt y) main(){ {if(x>y) return x;int a,b,c;else retur n y;scanf( “ %d%d ”,&a,&b);} c二fun( a,b);printf( “最大值为:%d ” ,c);}(1)函数的返回类型:在上面的例子中fun函数的返回值是int,如果将int改为double,很明显是错误的。
从两个地方来看,首先return x;中x的类型必须和fun函数中的返回值相同,x是整型。
其次c=fun(a,b);中fun函数将一个返回值赋值给了变量C,说明函数返回的值一定是整型。
记住:函数调用、函数的返回值和ruturn 中数据类型必须一致!(2) return 后面的表达式及其类型:⑶函数传递的参数:int fun (i nt *x,i nt *y) main(){ {if(*x>*y)return *x; int a,b,c;else return *y; scanf(“%d%d ”,&a,&b);} c=fun(&a,&b);printf(“最大值为:%d ” ,c);}一定注意:传递的是值还是地址。
比较上面两个例子大家很容易区别传递的是值还是地址,第一个例子调用函数的时候传递的是值,因此在fun函数的形参中x和y仅仅是普通的变量,而第二个例子中调用函数的时候传递的是地址,因此在fun函数的形参中x和y就是两个指针变量。
5(4)指针的使用:int fun (i nt *x,i nt *y){if(*x>*y)return *x;else return *y;}在此例中fun函数的形参是x和y,它们的类型是整型的指针,那么在fun函数的函数体中使用到x和y的值时一定要区分:x>y比较的是x和y所存变量地址的大小,*x>*y才是比较值的大小。
如果存在*x=x+y;的类似情况一定是错误的,必须要将赋值号的左右两边的类型变为一致。
7教组:(1)数组下标的初始值:数组下标从零开始,到长度减一结束。
考试技巧:当出错行在定义部分时,先检查该定义语句有没有语法错误,再看定义语句中的变量有没有赋初始值,最后看变量赋的初始值有没有正确。
定义初始值有窍门,遇到累加时,用来存放累加和的变量一般赋值为零,遇到求阶乘时,用来存放阶乘值的变量一般赋值为一。
(2)普通变量的初始值:依照上面的技巧,我们同样可以将它延伸到普通变量中。
(3)数组和字符串长度减一:当使用数组中的元素时,最大值只能到数组长度减一。
字符串以’\0' 作为字符串的结束标志,因此取值最大也只能到字符串长度减一(4)数组下标往后走:当题目要求将一个数组中的元素直接赋值或是以某种方式复制到另一个数组中时,接受数据的数组中的下标要自增。
8.特例:部分题目的解答很特殊,需要根据上下文中的内容来解答题目;9•素数掌握求素数的格式:判断一个数是否是素数的方法很多,的是只用掌握一种即可,首先掌握判断一个素数的方法;素数的定义:1、是自然数2、只能被1和本身整除,2到本身减一之间的数不能整除该数。
判断m是否为素数的格式:for(i=2;i<m;i++)if(m%i==O)break;if(m==i) 表明m 是素数;素数只能被1和m,那么用2到m-1之间的数除m,如果有一个数能整除m,说明m不是一个素数,就不用再判断后面的数值了,用一条break语句提前结束函数;如果一直都不能整除,则说明m 是一个素数。
那么用循环语句表示2到m-1之间的数的语句为:for(i=2;i<m;i++),如果在这个范围内的数值有一个数值能整除m,说明m不是一个素数,则可以提前结束循环,break;那么结束之后这个循环中的变量I的值小于m,如果m是一个素数的时候,则一直都不执行break语句;则循环语句结束的时候是在i==m的时候退出循环。
结束循环以后,进行i和m的比较,如果i小于m,则表明m不是一个素数;如果i等于m,则表明m是一个素数。
求素数的题目只要把格式给带进去就可以了。
10、链表链表的题目分为带头结点的和不带头结点的链表;1、带头结点的链表带头结点的链表的第一个空的改为:p=h->next ;第二个空改为:p=p->next;.2、不带头结点的链表带头结点的链表的第一个空的改为:p=h;第二个空改为:p=p->next;.。