1、计算机二级考试计算机二级考试 C 语言知识点总结语言知识点总结(完全针对考试大纲完全针对考试大纲)总体上必须清楚的总体上必须清楚的:1)程序结构是三种:顺序结构,循环结构(三个循环结构),选择结构(if 和 switch)2)读程序都要从 main()入口,然后从最上面顺序往下读(碰到循环做循环,碰到选择做选择)。3)计算机的数据在电脑中保存是以 二进制的形式.数据存放的位置就是 他的地址.4)bit 是位 是指为 0 或者 1。byte 是指字节,一个字节=八个位.000111105)一定要记住 二进制 与 十进制互化。概念常考到的:、编译预处理不是 C 语言的一部分,不再运行时间。C 语言
2、编译的程序称为源程序,它以 ASCII 数值存放在文本文件中。、每个 C 语言程序中 main 函数是有且只有一个。、在函数中不可以再定义函数。、算法的是一定要有输出的,他可以没有输入。、break 可用于循环结构和 switch 语句。、逗号运算符的级别最低。第一章1)合法的用户标识符考查:合法的要求是由字母,数字,下划线组成。有其它元素就错了。并且第一个必须为字母或则是下划线。第一个为数字就错了。关键字不可以作为用户标识符号。main define scanf printf if 都不是关键字。迷惑你的地方 If 是可以做为用户标识符。因为 If 中的第一个字母大写了,所以不是关键字。2)
3、实型数据的合法形式:2.333e0.1 就是合法的,且数据是 2.33310-1。考试口诀:e 前 e 后必有数,e 后必为整数。.3)字符数据的合法形式::1 是字符占一个字节,1是字符串占两个字节(含有一个结束符号)。0 的 ASCII 数值表示为 48,a 的 ASCII 数值是 97,A的 ASCII 数值是 65。4)整型一般是两个字节,字符型是一个字节,双精度一般是 4 个字节:考试时候一般会说,在 16 位编译系统,或者是 32 位系统。碰到这种情况,不要去管,一样做题。掌握整型一般是两个字节,字符型是一个字节,双精度一般是 4 个字节就可以了。5)转义字符的考查:在程序中 in
4、t a=0 x6d,是把一个十六进制的数给变量 a 注意这里的 0 x 必须存在。在程序中 int a=067,是一个八进制的形式。在转义字符中,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 任意字符 三位八进
5、制 xhh 任意字符 二位十六进制6)算术运算符号的优先级别:同级别的有的是从左到右,有的是从右到左。7)强制类型转换:一定是(int)a 不是 int(a),注意类型上一定有括号的。注意(int)(a+b)和(int)a+b 的区别。前是把 a+b 转型,后是把 a 转型再加 b。a=2.5 b=3.68)表达式的考查:是表达式就一定有数值。赋值表达式:表达式数值是最左边的数值,a=b=5;该表达式为 5,常量不可以赋值。自加、自减表达式:假设 a=5,+a(是为 6),a+(为 5);运行的机理:+a 是先把变量的数值加上 1,然后把得到的数值放到变量 a 中,然后+a表达式的数值为 6,
6、而 a+是先用该表达式的数值为 5,然后再把 a 的数值加上 1 为 6,再放到变量 a 中。进行了+a 和 a+后在下面的程序中再用到 a 的话都是变量 a 中的 6 了。a=5,b=6c=a-c=-a 考试口诀:+在前先加后用,+在后先用后加。逗号表达式:优先级别最低;表达式的数值是逗号最右边的那个表达式的数值。(2,3,4)的表达式的数值就是 4。9)位运算的考查:会有一到二题考试题目。总的处理方法:几乎所有的位运算的题目都要按这个流程来处理(先把十进制变成二进制再变成十进制)。例 1:char a=6,b;b=a2;这种题目的计算是先要把 a 的十进制 6 化成二进制,再做位运算。例
7、2:一定要记住,例 3:在没有舍去数据的时候,右移一位表示除以 2。10)018 的数值是非法的,八进制是没有 8 的,逢 8 进 1。11)%符号两边要求是整数。不是整数就错了。12)两种取整丢小数的情况:、int a=1.6;、(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)putcha
8、r,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(表
9、示假)当关系的表达是为真的时候得到 1。如 98 这个是真的,所以表达式的数值就是 1;2)逻辑表达式:只能为 1(表示为真),或 0(表示假)a)共有&|!三种逻辑运算符号。b)!&|优先的级别。c)注意短路现象。考试比较喜欢考到。d)要表示 x 是比 0 大,比 10 小的方法。0 x10 是不可以的(一定记住)。是先计算 0 x 得到的结果为 1 或则 0;再用 0,或 1 与 10 比较得到的总是真(为 1)。所以一定要用(0 x)&(x第一行a1 4 5 6 第二行a2 7 8 9 第三行步骤二:这样作题目间很简单:*(a0+1)我们就知道是第一行的第一个元素往后面跳一列,那么这里就
10、是 a01元素,所以是。*(a1+2)我们就知道是第二行的第一个元素往后面跳二列。那么这里就是 a12元素,所以是 6。一定记住:只要是二维数组的题目,一定是写成如上的格式,再去做题目,这样会比较简单。数组的初始化,一维和二维的,一维可以不写,二维第二个一定要写 int a=1,2 合法。int a4=2,3,4合法。但 int a4=2,3,4非法。二维数组中的行指针int a12;其中 a 现在就是一个行指针,a+1 跳一行数组元素。搭配(*)p2指针 a0,a1现在就是一个列指针。a0+1 跳一个数组元素。搭配*p2指针数组使用还有记住脱衣服法则:a2 变成 *(a+2)a23变成*(a
11、+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.必须在最
12、后 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 函数,系统总是
13、从该函数开始执行 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.02、
14、以下选项中,(D)是不正确的 C 语言字符型常量。A.a B.x41 C.101 D.a3、在 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.525、算术运算符、赋值运算符和关系运算符的运算优先级按从高到低依次为(B)。A.算术运算、赋值运算、关系运算 B.算术运算、关系运算、赋值运算 C.关系运算、赋值运算、算术运算 D.关系运算、算术运算、赋值运算 6、若有代数式,则
15、不正确的 C 语言表达式是(C)。A.a/b/c*e*3 B.3*a*e/b/c C.3*a*e/b*c D.a*e/c/b*3 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=ab)&(n=cd)后,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
16、.*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,则表达式:ab?a:cd?a:d 的结果为(D)。A.4 B.3 C.2 D.1 15、设 a 为整型变量,不能正确表达数学关系:10a15 的 C 语言表达式是(A)。A.10a
17、10&a15 D.!(a=15)16、设 f 是实型变量,下列表达式中不是逗号表达式的是(D)。A.f=3.2,1.0 B.f0,f0 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 语言中,要求运算对象只能为整数的运算符
18、是(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 二、填空题:1、C 语言中的逻辑值“真”是用 1 表示的,逻辑值“假”是用 0 表示的。2、若 x 和 n 都是 int 型变量,且 x 的初值为 12,n
19、的初值为 5,则计算表达式 x%=(n%=2)后 x 的值为 0 。3、设 c=w,a=1,b=2,d=-5,则表达式 x+1c,y!=c+2,-a-5*b100)y=x/100;printf(“%d”,y);else printf(“%d”,a+b);2.if 结构main()float t;char c;printf(“input score,max as 100:n”);scanf(“%f”,&t);if(t=90)ch=A;else if(t=80)ch=B;else if(t=70)ch=C;else if(t=60)ch=D;else ch=E;printf(“Grade=%dn”
20、,ch);switch 结构main()float t;char c;printf(“input score,max as 100:n”);scanf(“%f”,&t);switch(t/10)case 10:case 9:ch=A;break;case 8:ch=B;break;case 7:ch=C;break;case 6:ch=D;break;case 5:ch=E;printf(“Grade=%dn”,ch);五、选做题1.main()int a,b,c,t;scanf(“%d%d%d”,&a,&b,&c);if(ab)t=a;a=b;b=t;if(ac)t=a;a=c;c=t;if
21、(b0)&(s=3)&(s1)|(s8)case 1:x=3;break;case 0:x=1;break;break;case 0:x=0;break;循环结构答案一、选择题 1B 2.A 3.A 4.C 5.A 6.B 7.A 8.C 9.D 10.D 二、填空题1.x1 x1/2-22.ch=getchar()ch=A&ch=Z3.s=s+t*i t=-t 三、阅读下列程序,写出程序运行的输出结果 18522.89213.54.SUM=2468 四、程序改错1.main()int i=200,n=0;/*n 用来记录每行已打印数的个数*/while(i=300)if(i%7=0)/bre
22、ak;printf(%5d,i);n=n+1;if(n=5)/*满 5 个换行*/printf(n);n=0;i+;2).main()int i,s=0,t=1;for(i=1;i=7;i+)t=t*i;s=s+t;printf(sum=%dn,s);五、程序设计题1.main()int x,g,s,b;for(x=100;x1000;x+)b=x/100;s=x%100/10;g=x%10;if(g*g*g+s*s*s+b*b*b)=x)printf(“%dn”,x);2.main()int i,s=0,f=1;for(i=2;i80;i+)s=s+f*(i-1)/i;f=-f;printf
23、(s=%fn”,s);六、选做题1.main()float s=0,m=2.0,n=1.0,p;int i;for(i=1;i=20;i+)s=s+m/n;p=m;m=m+n;n=p;printf(s=%fn”,s);2.#include main()int i,j,k,s=1;for(i=1;i=20;i+)for(j=1;j=0)printf(“%2d%2d%2d”,i,j,k);s=s+1;if(s%5=0)printf(“n”);第 7 章 数组习题A 卷1.单项选择题(1)int a4=5,3,8,9;其中 a3的值为()。DA.5 B.3 C.8 D.9(2)以下 4 个字符串函数
24、中,()所在的头文件与其他 3 个不同。A A.gets B.strcpy C.strlen D.strcmp(3)以下 4 个数组定义中,()是错误的。DA.int a7;B.#define N 5 long bN;C.char c5;D.int n,dn;(4)对字符数组进行初始化,()形式是错误。BA.char c1=1,2,3;B.char c2=123;C.char c3=1,2,3,0;D.char c4=123;(5)在数组中,数组名表示()。AA.数组第 1 个元素的首地址 B.数组第 2 个元素的首地址 C.数组所有元素的首地址 D.数组最后 1 个元素的首地址(6)若有以下
25、数组说明,则数值最小的和最大的元素下标分别是()。Bint a12=1,2,3,4,5,6,7,8,9,10,11,12;A.1,12 B.0,11 C.1,11 D.0,12(7)若有以下说明,则数值为 4 的表达式是()。Dint a12=1,2,3,4,5,6,7,8,9,10,11,12;char c=a,d,g;A.ag-c B.a4 C.ad-c D.ad-c (8)设有定义:char s12=string;则 printf(%dn,strlen(s);的输出是()。AA.6 B.7 C.11 D.12(9)设有定义:char s12=string;则 printf(%dn,siz
26、eof(s);的输出是()。DA.6 B.7 C.11 D.12(10)合法的数组定义是()。AA.char a=string ;B.int a5=0,1,2,3,4,5;C.char a=string ;D.char a=0,1,2,3,4,5(11)合法的数组定义是()。DA.int a3=0,1,2,3,4,5;B.int a 3=0,1,2,3,4;C.int a23=0,1,2,3,4,5,6;D.int a23=0,1,2,3,4,5,;(12)下列语句中,正确的是()。DA.char a3=abc,1;B.char a 3=abc,1;C.char a3=a,1;D.char a
27、 3=a,1;(13)下列定义的字符数组中,输出 printf(%sn,str2);的输出是()。Cstatic str320=basic,foxpro,windows;A.basic B.foxpro C.windows D.输出语句出错(14)下列各语句定义了数组,其中哪一个是不正确的()。CA.char a310=China,American,Asia;B.int x22=1,2,3,4;C.float x2=1,2,4,6,8,10;D.int m3=1,2,3,4,5,6;(15)数组定义为 int a32=1,2,3,4,5,6,值为 6 的数组元素是()。BA.a32 B.a21
28、 C.a12 D.a23(16)下面的程序中哪一行有错误()。D#include main()float array5=0.0;/第 A 行 int i;for(i=0;i5;i+)scanf(%f,&arrayi);for(i=1;i5;i+)array0=array0+arrayi;/第 B 行 printf(%fn,array0);/第 C 行 A.第 A 行 B.第 B 行 C.第 C 行 D.没有(17)下面哪一项是不正确的字符串赋值或赋初值的方式()。C A.char*str;str=string;B.char str7=s,t,r,i,n,g;C.char str110;str1
29、=string;D.char str1=string,str2=12345678;(18)若有以下说明和语句,则输出结果是哪一项()。C (strlen(s)为求字符串 s 的长度的函数)char s12=a book!;printf(%d,strlen(s);A.12 B.8 C.7 D.11(19)若有以下说明和语句,则输出结果是()。B (strlen(s)为求字符串 s 的长度的函数)char sp=tv0willn;printf(%d,strlen(sp);A.14 B.3 C.9 D.字符串中有非法字符(20)若有以下说明和语句,则输出结果是()。C char str=c:abc.
30、dat;printf(%s,str);A.字符串中有非法字符 B.c:abc.dat C.c:abc.dat D.c:abc.dat 2.填空题(1)C 语言中,数组的各元素必须具有相同的 ,元素的下标下限为 ,下标必须是正整数、0、或者 。但在程序执行过程中,不检查元素下标是否 。数据类型,0,符号常量,越界(2)C 语言中,数组在内存中占一片 的存储区,由 代表它的首地址。数组名是一个 常量,不能对它进行赋值运算。连续,数组名,地址(3)执行 static int b5,a 3=1,2,3,4,5,6;后,b4=,a12=。0,6(4)设有定义语句 static int a34=1,2,3
31、;则 a10值为 ,a11 值为 ,a21的值为 。2,0,0(5)如定义语句为 char a=windows,b=95;,语句 printf(%s,strcat(a,b);的输出结果为 。Windows95(6)根据以下说明,写出正确的说明语句:men 是一个有 10 个整型元素的数组。step 是一个有 4 个实型元素的数组,元素值分别为 1.9,-2.33,0,20.6。grid 是一个二维数组,共有 4 行,10 列整型元素。int mesh10;float step4=1.9,-2.33,0,20.6;int grid410;(7)array 是一个一维整形数组,有 10 个元素,前
32、 6 个元素的初值是 9,4,7,49,32,-5,正确的说明语句为:。该数组下标的取值范围是从_到_(从小到大)。用 scanf 函数输入数组的第二个元素表示为:。用赋值语句把 39 存入第一个元素表示为:。把第六个和第四个元素之和存入第一个元素表示为:。int array10=9,4,7,49,32,-5;0 9 scanf(%d,&array1);array0=39;array0=array5+array3;(8)写出以下初始化数组的长度:int chn3;数组 chn 的长度为_。float isa=1.0,2.0,3.0,4.0,5.0;数组 isa 的长度为_。int doom8;
33、数组 doom 的长度为_。float pci42;数组 pci 的长度为_。int ast33;数组 ast 的长度为_。int att34;数组 att 的长度为_。float dell3=1,4,7,2,5,3,6,9;数组 dell 的长度为_。6 20 16 32 18 24 36(9)若有以下整型的 a 数组,数组元素和它们得值如下所示:数组元素:a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 元素的值:9 4 12 8 2 10 7 5 1 3 请写出对该数组的说明,并赋以上初值。该数组的最小下标值为_,最大下标值为_。写出下面各式的值:aa9的值为_;aa4+a8的
34、值为_。int a10=9,4,12,8,2,10,7,5,1,3;0 9 8 8(10)字符串abn012/的长度为_。10 3.判断题()(1)C 允许对数组的大小作动态定义,即可用变量定义数组的大小。()(2)字符数组不要求它的最后一个字符为0,甚至可以不包含0。()(3)数组定义 int a10;也可以写成 int a(10);。()(4)在对全部数组元素赋初值时,可以不指定数组长度。()(5)定义 s 为 56(5 行 6 列)的数组可写成 float a5,6;()(6)数组定义 int a10;表示数组名为 a,此数组有 10 个元素。()(7)数组定义 int a10;表示数组
35、名为 a,此数组有 10 个元素,第 10 个元素为a10。()(8)static char c=“a book”;与 static char c=“a book”;等价。()(9)static char c=a,b,o,o,k,0;与 static char c=a,b,o,o,k;等价。()(10)设已有说明:static char c110,c210;下面程序片段是合法的。c1=“book”;c2=c1;4.程序填空题(1)输入 20 个数,输出它们的平均值,输出与平均值之差的绝对值为最小的数组元素。请填空。#include void main()float a20,pjz=0,s,t;
36、int i,k;for(i=0;i20;i+)pjz+=ai;s=fabs(a0-pjz);for(i=1;i20;i+)if(fabs(ai-pjz)s)s=fabs(ai-pjz);t=ai;-for(i=0;i20;i+)scanf(“%f”,&ai);pjz/=20;printf(“%f,%fn”,piz,t);(2)以下程序以每行 10 个数据的形式输出 a 数组,请填空。void main()int a50,i;printf(输入 50 个整数:);for(i=0;i50;i+)scanf(%d,);for(i=1;i=50;i+)if()printf(%3dn,);printf(
37、%3d,ai-1);&ai i%10=0 ai-1(3)下面程序的功能是输出数组 s 中最大元素的下标,请填空。void main()int k,p;int s=1,-9,7,2,-10,3;for(p=0,k=p;psk);printf(%dn,k);k=p(4)这个程序输入了 20 个数存放在一个数组中,并且输出其中最大者与最小者、20 个数的和及它们的平均值。请填空。void main()char array ;int max,min,average,sum;int i;for(i=0;i ;i+)printf(请输入第%d 个数:,i+1);scanf(%d,);max=array0;
38、min=array0;for(i=0;i=;i+)if(maxarrayi)sum=;average=;printf(20 个数中最大值是%d,max);printf(最小值是%d,min);printf(和是%d,sum);printf(平均值是%d.n,average);20 20&arrayi 19 max=arrayi;min=arrayi;sum+arrayi sum/20 B 卷5.阅读程序,分析程序的功能。(1)#include#include void main()char s80;int i;for(i=0;i80;i+)si=getchar();if(si=n)break;
39、si=0;i=0;while(si)putchar(si+);putchar(n);从键盘输入一个字符串,并逐一输出(2)#include#include void main()char str1080,c80;int i;for(i=0;i10;i+)gets(stri);strcpy(c,str0);for(i=1;i10;i+)if(strlen(c)strlen(stri)strcpy(c,stri);printf(%sn,c);printf(%dn,strlen(c);从键盘输入若干字符串,找到其中最长的一个输出及它的长度(3)#include#include void main()
40、char a1080,c80;int i,j,k;for(i=0;i10;i+)gets(ai);for(i=0;i9;i+)k=i;for(j=i+1;j10;j+)if(strcmp(a j,ak)0)k=j;if(k!=i)strcpy(c,ai);strcpy(ai,ak);strcpy(ak,c);/字符串交换 for(i=0;i10;i+)puts(ai);从键盘输入若干字符串,并将它们按大到小顺序排好再输出(4)阅读程序,写出运行结果#include void main()int a6=12,4,17,25,27,16,b6=27,13,4,25,23,16,i,j;for(i=
41、0;i6;i+)for(j=0;j6;j+)if(ai=bj)break;if(j6)printf(%d,ai);printf(n);4 25 27 16(5)阅读程序,写出运行结果。#include void main()char a8,temp;int j,k;for(j=0;j7;j+)aj=a+j;a7=0;for(j=0;j0;k-)ak=ak-1;a0=temp;printf(%sn,a);gabcdeffgabcdeefgabcd(6)阅读下列程序,写出程序运行的输出结果。#include#include void main()char str1=*;for(int i=0;i4
42、;i+)printf(%sn,str1);str1i=;str1strlen(str1)-1=0;*(7)该程序的运行结果是:min=,m=,n=。void main()float array43=3.4,-5.6,56.7,56.8,999.,-.0123,0.45,-5.77,123.5,43.4,0,111.2 ;int i,j;int min;int m,n;min=array00;m=0;n=0;for(i=0;i3;i+)for(j=0;j arrayij)min=arrayij;m=i;n=j;printf(min=%d,m=%d,n=%dn,min,m,n);-5.77 2 1
43、(8)写出下面这个程序的输出结果:void main()char str=ABCDEFGHIJKL;printf(%sn,str);屏幕上显示 printf(%sn,&str4);屏幕上显示 str2=str5;printf(%sn,str);屏幕上显示 str9=0;printf(%sn,str);屏幕上显示 ABCDEFGHIJKLEFGHIJKLABFDEFGHIJKLABFDEFGHI(9)读懂下面的程序并填空。void main()char str80;int i=0;gets(str);while(stri!=0)if(stri=a&str=z)stri-=32;i+;puts(s
44、tr);程序运行时如果输入 upcase,屏幕显示 程序运行时如果输入 Aa1Bb2Cc3,屏幕显示 UPCASEAA1BB2CC第 8 章 函数习题A 卷1.单项选择题(1)C 语言总是从 函数开始执行。AA.main B.处于最前的 C.处于最后的 D.随机选一个(2)函数在定义时,省略函数类型说明符,则该函数值的类型为 。A A.int B.float C.long D.double(2)以下 函数,真正地没有返回值。BA.int a()int a=2;return(a);B.void b()printf(c);C.int a()int a=2;return a;D.以上都是(3)在 C
45、 语言中,有关函数的说法,以下正确的是 。AA.函数可嵌套定义,也可嵌套调用 B.函数可嵌套定义,但不可嵌套调用 C.函数不可嵌套定义,但可嵌套调用 D.函数不可嵌套定义,也不可嵌套调用(4)以下函数调用语句中,含有实参的个数为 。C fun(2,3),(4,5+6,7);A.1 B.2 C.5 D.6(5)函数调用可以在 。DA.函数表达式中 B.函数语句中 C.函数参数中 D.以上都是(6)被调函数返回给主调函数的值称为 。C A.形参 B.实参 C.返回值 D.参数(7),可以不进行函数类型说明。DA.被调函数的返回值是整型或字符型时 B.被调函数的定义在主调函数定义之前时 C.在所有函
46、数定义前,已在函数外预先说明了被调函数类型 D.以上都是 (8)被调函数通过 语句,将值返回给主调函数。DA.if B.for C.while D.return(9)被调函数调用结束后,返回到 。DA.主调函数中该被调函数调用语句处 B.主函数中该被调函数调用语句处 C.主调函数中该被调函数调用语句的前一语句 D.主调函数中该被调函数调用语句的后一语句(10)以下对 C 语言函数的有关描述中,正确的是 。AA.在 C 中,调用函数时,只能把实参的值传送给形参,形参的值不能传送给实参 B.C 函数既可以嵌套定义又可递归调用 C.函数必须有返回值,否则不能使用函数 D.C 程序中有调用关系的所有函
47、数必须放在同一个源程序文件中(11)C 语言中函数的隐含存储类型是 。CA.auto B.static C.extern D.无存储类型(12)能把函数处理结果的两个数据返回给主调函数,在下面的方法中不正确的是 。AA.return 这两个数 B.形参用两个元素的数组 C.形参用两个这种数据类型的指针 D.用两个全局变量(13)C 语言可执行程序从什么地方开始执行()。CA.程序中第一条可执行语句 B.程序中第一个函数C.程序中的 main 函数 D.包含文件中的第一个函数(14)有一个函数原型如下所示,则该函数的返回类型为()。C abc(float x,float y);A.void B.
48、double C.int D.float 2.填空题(1)变量的作用域主要取决于变量 ,变量的生存期既取决于变量 ,又取决于变量 。所处的位置,所处的位置,存储类型(2)说明变量时,若省略存储类型符,系统默认其为 存储类别,该存储类别的类型符为:。动态,auto(3)静态型局部变量的作用域是 ,生存期是 。它所在的局部,整个程序(4)函数中的形参和调用时的实参都是数组名时,传递方式为 ,都是变量时,传递方式为 。址传递,值传递(5)函数的形式参数的作用域为 ,全局的外部变量和函数体内定义的局部变量重名时,_变量优先。该函数中,局部(6)若自定义函数要求返回一个值,则应在该函数体中有一条 语句,
49、若自定义函数要求不返回一个值,则应在该函数说明时加一个类型说明符 。return,void(7)若函数的形式参数是指针类型,则实参可以是 或 。指针,数组名(8)函数的参数为 char*类型时,形参与实参结合的传递方式为 。址传递(9)函数的实参为常量时,形参与实参结合的传递方式为 。值传递(10)下面这个函数的功能是求两个整数的积,并通过形参传回结果,请填空。int int int*resultvoid mul(_x,_y,_result)_=x*y;3.判断题()(1)函数说明指的是在程序中设定一个函数模块。()(2)形参只有在被调用时才分配存储空间。()(3)在 C 的函数中,最好使用全
50、局变量。()(4)在调用函数时,实参传值给形参,调用结束时,形参值传给实参。()(5)所有函数定义都是并行的,相互独立的。()(6)函数的隐含存储类型是 extern。()(7)形参可以是常量、变量或表达式。()(8)函数调用可以作为一个函数的形参。()(9)C 语言规定,实参应与其对应的形参类型一致。()(10)定义函数时,形参的类型说明可以放在函数体内。4.程序填空题(1)对数组按值从大到小的顺序排序后输出,请填空。#include void main()float a7=2,6,3,8,3,12,9;int i;void sort(float*,int);for(i=0;i7;i+)pr