二级C
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了二级C相关的知识,希望对你有一定的参考价值。
2016年全国计算机等级考试二级C语言考试大纲+二级C复习指南
◆ 基本要求
1.熟悉Visual C++ 6.0 集成开发环境。
2.掌握结构化程序设计的方法,具有良好的程序设计风格。
3.掌握程序设计中简单的数据结构和算法并能阅读简单的程序。
4.在 Visual C++ 6.0 集成环境下,能够编写简单的C 程序,并具有基本的纠错和调试程序的能力
◆ 考试内容
一、C 语言程序的结构
1.程序的构成,main函数和其他函数。
2.头文件,数据说明,函数的开始和结束标志以及程序中的注释。
3.源程序的书写格式。
4.C 语言的风格。
二、数据类型及其运算
1.C 的数据类型(基本类型,构造类型,指针类型,无值类型)及其定义方法。
2.C 运算符的种类、运算优先级和结合性。
3.不同类型数据间的转换与运算。
4.C 表达式类型(赋值表达式,算术表达式,关系表达式,逻辑表达式,条件表达式,逗号表达式)和求
值规则。
三、基本语句
1.表达式语句,空语句,复合语句。
2.输入输出函数的调用,正确输入数据并正确设计输出格式。
四、选择结构程序设计
1.用 if 语句实现选择结构。
2.用 switch 语句实现多分支选择结构。
3.选择结构的嵌套。
五、循环结构程序设计
1.for 循环结构。
2.while 和 do-while 循环结构。
3.continue 语句和 break 语句。
4.循环的嵌套。
六、数组的定义和引用
1.一维数组和二维数组的定义、初始化和数组元素的引用。
2.字符串与字符数组。
七、函数
1.库函数的正确调用。
2.函数的定义方法。
3.函数的类型和返回值。
4.形式参数与实在参数,参数值传递。
5.函数的正确调用,嵌套调用,递归调用。
- 1 -
6.局部变量和全局变量。
7.变量的存储类别(自动,静态,寄存器,外部),变量的作用域和生存期。
八、编译预处理
1.宏定义和调用(不带参数的宏,带参数的宏)。
2.“文件包含”处理。
九、指针
1.地址与指针变量的概念,地址运算符与间址运算符。
2.一维、二维数组和字符串的地址以及指向变量、数组、字符串、函数、结构体的指针变量的定义。通
过指针引用以上各类型数据。
3.用指针作函数参数。
4.返回地址值的函数。
5.指针数组,指向指针的指针。
十、结构体(即“结构”)与共同体(即“联合”)
1.用 typedef 说明一个新类型。
2.结构体和共用体类型数据的定义和成员的引用。
3.通过结构体构成链表,单向链表的建立,结点数据的输出、删除与插入。
十一、位运算
1.位运算符的含义和使用。
2.简单的位运算。
十二、文件操作
只要求缓冲文件系统(即高级磁盘 I/O 系统),对非标准缓冲文件系统(即低级磁盘I/O 系统)不要求。
1. 文件类型指针(FILE 类型指针)
2.文件的打开与关闭(fopen,fclose)。
3.文件的读写(fputc,fgetc,fputs,fgets,fread,fwrite,fprintf,fscanf 函数的应用),文件的定位(rewind,
fseek 函数的应用)。
考试题型
(1)选择。——40
(2)程序填空。——18
(3)程序改错。——18
(4)程序编程。——24
总体上必须清楚的:
1)程序结构是三种: 顺序结构 , 循环结构(三个循环结构), 选择结构(if 和 switch)
2)读程序都要从 main()入口, 然后从最上面顺序往下读(碰到循环做循环,碰到选择做选择)。
3)计算机的数据在电脑中保存是以二进制的形式. 数据存放的位置就是他的地址.
4)bit 是位 是指为 0 或者 1。 byte 是指字节, 一个字节 = 八个位.
5)一定要记住二进制如何划成十进制。
概念常考到的:
1、编译预处理不是C 语言的一部分,不再运行时间。C 语言编译的程序称为源程序,它以ASCII 数值存放在文本文件中。
2、每个C 语言程序中 main 函数是有且只有一个。
3、在函数中不可以再定义函数。
4、算法的是一定要有输出的,他可以没有输入。
5、break 可用于循环结构和switch 语句。
6、逗号运算符的级别最低。
第一章
1)合法的用户标识符考查:
合法的要求是由字母,数字,下划线组成。有其它元素就错了。
并且第一个必须为字母或则是下划线。第一个为数字就错了。
关键字不可以作为用户标识符号。main define scanf printf 都是关键字。迷惑你的地方 If 是可以做为用
户标识符。因为 If 中的第一个字母大写了,所以不是关键字。
2)实型数据的合法形式:
2.333e-1 就是合法的,且数据是 2.333×10^-1
考试口诀:e 前 e 后必有数,e后必为整数。.
3)字符数据的合法形式::
‘1‘ 是字符占一个字节,"1"是字符串占两个字节(含有一个结束符号)。
‘0‘ 的 ASCII 数值表示为 48,‘a‘ 的 ASCII 数值是 97,‘A‘的 ASCII 数值是 65。
4) 整型一般是两个字节, 字符型是一个字节,双精度一般是 4 个字节:
考试时候一般会说,在16 位编译系统,或者是32 位系统。碰到这种情况,不要去管,一样做题。掌
握整型一般是两个字节, 字符型是一个字节,双精度一般是 4 个字节就可以了。
5)转义字符的考查:
在程序中 int a = 0x6d,是把一个十六进制的数给变量 a,注意这里的 0x 必须存在。
在程序中 int a = 06d, 是一个八进制的形式。
在转义字符中,’\x6d’ 才是合法的,0 不能写,并且 x 是小写。
‘\141’ 是合法的。
‘\108’是非法的,因为不可以出现 8。
转义字符 意义 ASCII 码值(十进制)
\a 响铃(BEL) 007
\b 退格(BS) 008
\f 换页(FF) 012
\n 换行(LF) 010
\r 回车(CR) 013
\t 水平制表(HT) 009
\v 垂直制表(VT) 011
\\ 反斜杠 092
\? 问号字符 063
\‘ 单引号字符 039
\" 双引号字符 034
\0 空字符(NULL) 000
\ddd 任意字符 三位八进制
\xhh 任意字符 二位十六进制
6)算术运算符号的优先级别:
同级别的有的是从左到右,有的是从右到左。
7)强制类型转换:
一定是 (int)a 不是 int(a),注意类型上一定有括号的。
注意(int)( a+b)和(int)a+b 的区别。 前是把a+b 转型,后是把a 转型再 b。
8)表达式的考查:
是表达式就一定有数值。
赋值表达式:表达式数值是最左边的数值,a=b=5;该表达式为5,常量不可以赋值。
自加、自减表达式:假设 a=5,++a(是为 6), a++(为 5);
运行的机理:++a 是先把变量的数值加上1,然后把得到的数值放到变量a 中,然后再用这 个++a 表达式的数值为6,
而 a++是先用该表达式的数值为5,然后再把 a 的数值加上1 为 6,
再放到变量 a 中。 进行了++a 和 a++后在下面的程序中再用到 a 的话都是变量 a 中的 6 了。
考试口诀:++在前先加后用,++在后先用后加。
逗号表达式:优先级别最低;表达式的数值逗号最右边的那个表达式的数值。
(2,3,4)的表达式的数值就是 4。
9)位运算的考查: 会有一到二题考试题目。
总的处理方法:几乎所有的位运算的题目都要按这个流程来处理(先把十进制变成二进制再变成十进制)。
例 1: char a = 6, b;
b = a<<2; 这种题目的计算是先要把 a 的十进制 6 化成二进制,再做位运算。
一定要记住,在没有舍去数据的时候,<<左移一位表示乘以2;>>右移一位表示除以 2。
10)018 的数值是非法的,八进制是没有 8 的,逢8 进 1。
11)%符号两边要求是整数。不是整数就错了。
12) 两种取整丢小数的情况:
1、int a =1.6;
2、(int)a;
第二章
1)printf 函数的格式考查:
%d 对应整型;%c 对应字符;%f 对应单精度等等。宽度的,左对齐等修饰。
%ld 对应 long int;%lf 对应 double。
2)scanf 函数的格式考察:
注意该函数的第二个部分是&a这样的地址,不是a;
Scanf(“%d%d%*d%d”,&a,&b,&c); 跳过输入的第三个数据。
3)putchar ,getchar函数的考查:
char a = getchar() 是没有参数的,从键盘得到你输入的一个字符给变量 a。
putchar(‘y’)把字符 y 输出到屏幕中。
4)如何实现两个变量x ,y 中数值的互换(要求背下来)
不可以把 x=y ,y=x; 要用中间变量 t=x;x=y;y=t。
5)如何实现保留三位小数,第四位四舍五入的程序,(要求背下来)
x=(int)(x*1000+0.5)/1000.0
这个有推广的意义,注意 x = (int)x 这样是把小数部分去掉。
第三章
特别要注意:c语言中是用非 0 表示逻辑真的,用 0 表示逻辑假的。
1)关系表达式:
表达式的数值只能为1(表示为真),或0(表示假)
当关系的表达是为真的时候得到1。如 9>8 这个是真的,所以表达式的数值就是1;
2)逻辑表达式:
只能为 1(表示为真),或 0(表示假)
a) 共有&& || ! 三种逻辑运算符号。
b) !>&&>|| 优先的级别。
c) 注意短路现象。考试比较喜欢考到。
d) 要表示 x 是比 0 大,比 10 小的方法。0<x<10 是不可以的(一定记住)。是先计算 0<x 得到的结
果为 1 或则 0;再用 0,或 1 与 10 比较得到的总是真(为1)。所以一定要用 (0<x)&&(x<10)表示比 0 大比
10 小。
3)if 语句
else 是与最接近的 if 且没有 else 的相组合的。
4)条件表达式:
表达式 1 ?表达式 2 :表达式 3
注意是当非 0 时候是表达式 2 的数值,当为 0 是就是表达式 3 的数值。
考试口诀:真前假后。
5)switch 语句:
a)一定要注意 有 break 和没有 break 的差别,没有 break 时候,只要有一个case 匹配了,剩下的都要执行,
有 break 则是直接跳出了swich 语句。
b)switch 只可以和 break 一起用,不可以和 continue 用。
第四章
1)三种循环结构:
a)for() ; while(); do- while()三种。
b)for 循环当中必须是两个分号,千万不要忘记。
c)写程序的时候一定要注意,循环一定要有结束的条件,否则成了死循环。
d) do-while()循环的最后一个while();的分号一定不能够丢。(当心上机改错)
2) break 和 continue 的差别
记忆方法:
break:是打破的意思,(破了整个循环)所以看见 break 就退出整个一层循环。
continue:是继续的意思,(继续循环运算),但是要结束本次循环,就是循环体内剩下的语句不再执行,跳到循环开始,然后判断循环条件,进行
新一轮的循环。
3)嵌套循环
就是有循环里面还有循环,这种比较复杂,要一层一层一步一步耐心的计算,一般记住两层是处理二维
数组的。
4) while((c=getchar())!=’\n’) 和 while(c=getchar() !=’\n’)的差别
先看 a = 3 != 2 和 (a=3)! =2 的区别:
(!=号的级别高于=号 所以第一个先计算 3!=2) 第一个 a 的数值是得到的 1;第二个 a 的数值是 3。
考试注意点: 括号在这里的重要性。
第五章
函数:是具有一定功能的一个程序块;
1) 函数的参数,返回数值(示意图):
main()
{
int a = 5,b=6,c;
c = add(a,b);
printf(“%d”,c);
}
调用函数
a,b 是实参
整个函数得到一个数值就是
Add 函数的返回数值。
int add ( int x, int y)
{
int z;
z=x+y;
return z;
}
被调用函数
x,y 是形式参数
函数返回数值是整型
z 就是这个 add 函数计算后得到的结果,就是函数返回给主程序的返回数值。
程序是在从上往下顺序执行,当碰到了函数 add 后,把 a,b 的数值穿给调用函数,程序暂时中断等待返回
数值。当得到了返回数值后,再顺序的往下执行
2)一定要注意参数之间的传递
实参和形参之间 传数值,和传地址的差别。(考试的重点)
传数值的话,形参的变化不会改变实参的变化。
传地址的话,形参的变化就会有可能改变实参的变化。
3)函数声明的考查:
一定要有:函数名,函数的返回类型,函数的参数类型。
不一定要有:形参的名称。
第六章
指针变量的本质是用来放地址,而一般的变量是放数值的。
int *p 中 *p 和 p 的差别:
*p 可以当做变量来用;*的作用是取后面地址p 里面的数值
p 是当作地址来使用。
*p++ 和 (*p)++的之间的差别:改错题目中很重要
*p++是 地址会变化。
(*p)++ 是数值会要变化。
三名主义:(考试的重点)
数组名:表示第一个元素的地址。数组名不可以自加,他是地址常量名。(考了很多次)
函数名:表示该函数的入口地址。
字符串常量名:表示第一个字符的地址。
第七章
1 一维数组的重要概念:
对 a[10]这个数组的讨论。
1、a 表示数组名,是第一个元素的地址,也就是元素 a[0]的地址。
2、a 是地址常量,所以只要出现 a++,或者是 a=a+2 赋值的都是错误的。
3、a 是一维数组名,所以它是列指针,也就是说 a+1 是跳一列。
4、对 a[3][3]的讨论。
a[0]、a[1]、a[2]也都是地址常量,不可以对它进行赋值操作,同时它们都是列指针,a[0]+1,a[1]+1,
a[2]+1 都是跳一列。
注意 a 和 a[0] 、a[1]、a[2]是不同的,它们的基类型是不同的。前者是一行元素,后三者是一列元素。
二维数组做题目的技巧:
如果有 a[3][3]={1,2,3,4,5,6,7,8,9}这样的题目。
步骤一:把他们写成
第一列 第二列 第三列
a[0]à 1 2 3 ->第一行
a[1]à 4 5 6 —>第二行
a[2]à 7 8 9 ->第三行
步骤二:这样作题目间很简单:
*(a[0]+1)我们就知道是第一行的第一个元素往后面跳一列,那么这里就是a[0][1]元素,所以是1。
*(a[1]+2)我们就知道是第二行的第一个元素往后面跳二列。那么这里就是a[1][2]元素,所以是6。
一定记住:只要是二维数组的题目,一定是写成如上的格式,再去做题目,这样会比较简单。
数组的初始化,一维和二维的,一维可以不写,二维第二个一定要写
int a[]={1,2} 合法。 int a[][4]={2,3,4}合法。但 int a[4][]={2,3,4}非法。
二维数组中的行指针
int a[1][2];
其中 a 现在就是一个行指针,a+1 跳一行数组元素。 搭配(*)p[2]指针
a[0],a[1]现在就是一个列指针。a[0]+1跳一个数组元素。搭配*p[2]指针数组使用
还有记住脱衣服法则:
a[2] 变成 *(a+2) a[2][3]变成 *(a+2)[3]再可以变成 *(*(a+2)+3)
这个思想很重要!
第一章 C 语言概述
一、选择题:
1、一个 C 程序的执行是从( A )。
A 本程序的 main 函数开始,到 main 函数结束
B 本程序文件的第一个函数开始,到本程序文件的最后一个函数结束
C 本程序的 main 函数开始,到本程序文件的最后一个函数结束
D 本程序文件的第一个函数开始,到本程序 main 函数结束
2、 在 C 语言中,每个语句必须以( D )结束。
A. 回车符 B. 冒号 C. 逗号 D. 分号
3、C 语言规定:在一个源程序中,main 函数的位置( C )。
A. 必须在最开始 B. 必须在系统调用的库函数的后面
C. 可以任意 D. 必须在最后
4、一个 C 语言程序是由( B )。
A. 一个主程序和若干子程序组成 B. 函数组成
C. 若干过程组成 D. 若干子程序组成
5、下列说法中错误的是( D )。
A. 主函数可以分为两个部分:主函数说明部分和主函数体
B. 主函数可以调用任何非主函数的其他函数
C. 任何非主函数可以调用其他任何非主函数
D. 程序可以从任何非主函数开始执行
6、用 C 语言编写的源文件经过编译,若没有产生编译错误,则系统将( C )。
A. 生成可执行目标文件 B. 生成目标文件
C. 输出运行结果 D. 自动保存源文件
二、填空题:
1、C 语言只有 32 个关键字和 9 种控制语句。
2、每个源程序有且只有一个 main 函数,系统总是从该函数开始执行 C 语言程序。
3、C 语言程序的注释可以出现在程序中的任何地方,它总是以 \* 符号作为开始标记,以 */
符号作为结束标记。
4、C 语言中,输入操作是由库函数 scanf 完成的,输出操作是由库函 数 printf 完成的。
5、系统默认的C 语言源程序文件的扩展名是.c ,经过编译后生成的目标文件的扩展名是 .obj ,
经过连接后生成的可执行文件的扩展名是 .exe 。
6、C 语言的标识符只能由字母、数字和下划线三种字符组成。
第三章数据类型、运算符和表达式
一、选择题:
1、以下选项中,不正确的C 语言浮点型常量是( C )。
A. 160. B. 0.12 C. 2e4.2 D. 0.0
2、以下选项中,( D )是不正确的C 语言字符型常量。
A. ‘a‘ B. ‘\x41‘ C. ‘\101‘ D. "a"
3、 在 C 语言中,字符型数据在计算机内存中,以字符的( C )形式存储。
A. 原码 B. 反码 C. ASCII 码 D. BCD 码
4、若 x、i、j 和 k 都是 int 型变量,则计算下面表达式后,x的值是( C )。
x=(i=4,j=16,k=32)
A. 4 B. 16 C.32 D.52
5、算术运算符、赋值运算符和关系运算符的运算优先级按从高到低依次为( B )。
A. 算术运算、赋值运算、关系运算 B. 算术运算、关系运算、赋值运算
C. 关系运算、赋值运算、算术运算 D. 关系运算、算术运算、赋值运算
7、表达式!x||a==b 等效于( D )。
A. !((x||a)==b) B. !(x||y)==b C. !(x||(a==b)) D. (!x)||(a==b)
8、设整型变量 m,n,a,b,c,d 均为 1,执行 (m=a>b)&&(n=c>d)后, m,n 的值是( A)。
A. 0,0 B. 0,1 C. 1,0 D. 1,1
9、 设有语句 int a=3;,则执行了语句 a+=a-=a*=a;后,变量 a 的值是( B )。
A. 3 B. 0 C. 9 D. -12
10、在以下一组运算符中,优先级最低的运算符是( D )。
A. * B. != C. + D. =
11、设整型变量 i 值为 2,表达式(++i)+(++i)+(++i)的结果是( B )。
A. 6 B. 12 C. 15 D. 表达式出错
12、若已定义 x 和 y 为 double 类型,则表达式 x=1,y=x+3/2 的值是( C )。
A. 1 B. 2 C. 2.0 D. 2.5
13、sizeof (double)的结果值是( A )。
A. 8 B. 4 C. 2 D. 出错
14、设 a=1,b=2,c=3,d=4,则表达式:a<b? a : c<d? a : d 的结果为( D )。
A. 4 B. 3 C. 2 D. 1
15、设 a 为整型变量,不能正确表达数学关系:10<a<15的 C 语言表达式是( A )。
A. 10<a<15 B. a= =11|| a= =12 || a= =13 || a= =14
C. a>10 && a<15 D. !(a<=10) && !(a>=15)
16、设 f 是实型变量,下列表达式中不是逗号表达式的是( D )。
A. f= 3.2, 1.0 B. f>0, f<10 C. f=2.0, f>0 D. f=(3.2, 1.0)
17、 表达式18/4*sqrt(4.0)/8 值的数据类型是( C )。
A. int B. float C. double D. 不确定
18、已知字母 A 的 ASCII 码为十进制数 65,且 c2 为字符型,则执行语句
C2=’A’+’6’-‘3’;后 c2 中的值是( A )。
A. D B. 68 C. 不确定的值 D. C
19、以下用户标识符中,合法的是( B )。
A. int B. nit C. 123 D. a+b
20、C 语言中,要求运算对象只能为整数的运算符是( A )。
A. % B. / C. > D. *
21、若有说明语句:char c=‘\72‘;则变量 c 在内存占用的字节数是( A )。
A. 1 B. 2 C. 3 D. 4
22、字符串"ABC"在内存占用的字节数是( B )。
A. 3 B. 4 C. 6 D. 8
23、要为字符型变量 a 赋初值,下列语句中哪一个是正确的( B )。
A. char a="3"; B. char a=’3’; C. char a=%; D. char a=*;
24、下列不正确的转义字符是( C )。
A. \\ B. \‘ C. 074 D. \0
以上是关于二级C的主要内容,如果未能解决你的问题,请参考以下文章