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