1、二级 C 语言笔试-102 及答案解析(总分:100.00,做题时间:90 分钟)一、选择题(总题数:40,分数:70.00)1.以下函数 findmax 拟实现在数组中查找最大值并作为函数值返回,但程序中有错导致不能实现预定功能,造成错误的原因是#define MIN -2147483647int findmax (int X, int n)int i, max;for(i=0; in; i+)max=MIN;if(maxxi) max=xi;return max;(分数:2.00)A.定义语句 int i, max; 中 max 未赋初值B.赋值语句 max=MIN;中,不应给 max 赋
2、 MIN 值C.语句 if(maxxi) max=xi;中判断条件设置错误D.赋值语句 max=MIN;放错了位置2.数据库管理系统是(分数:2.00)A.操作系统的一部分B.在操作系统支持下的系统软件C.一种编译系统D.一种操作系统3.下列叙述中正确的是(分数:2.00)A.程序设计的任务就是编写程序代码并上机调试B.程序设计的任务就是确定所用数据结构C.程序设计的任务就是确定所用算法D.以上 3 种说法都不完整4.软件详细设计产生的图如图所示,该图是(分数:2.00)A.B.C.D.5.以下程序运行后的输出结果是#includestdio.hmain()int a=2, 3, 5, 4,
3、i;for(i=0; i4; i+)switch(i%2)case 0: switch(ai%2)case 0:ai+: break;case 1: ai-;break;case i: ai=0;for(i=0; i4; i+) printf(“%d“, ai); printf(“/n“);(分数:2.00)A.3 3 4 4B.2 0 5 0C.3 0 4 0D.0 3 0 46.有以下定义语句,编译时会出现编译错误的是(分数:2.00)A.char a=a;B.char a=/n;C.char a=aa;D.char a=/x2d;7.下列数据结构中,能够按照“先进后出”原则存取数据的是(
4、分数:2.00)A.循环队列B.栈C.队列D.二叉树8.以下程序段的输出结果是int r=8;printf(“%d/n“, r 1);(分数:2.00)A.16B.8C.4D.29.设有以下函数void fun(int n, char *s) 则下面对函数指针的定义和赋值均正确的是(分数:2.00)A.void(*pf)(); pf=fun;B.viod *pf(); pf=fun;C.void *pf(); *pf=fun;D.void(*pf)(int, char); pf=10.若有定义语句:int a410,*p, *q4;且 0i4,则错误的赋值是(分数:2.00)A.P=aB.qi
5、=aiC.P=aiD.P=s=f(a+1); t=f(a+1);printf(“%d, %d/n“, s, t);(分数:1.00)A.10,64B.10,10C.64,10D.64,6414.下列选择项中不属于结构化程序设计原则的是(分数:1.00)A.可封装B.自顶向下C.模块化D.逐步求精15.下面结构体的定义语句中,错误的是(分数:1.00)A.struct ordint x; int y; int z; struct ord a;B.struct ordint x; int y; int z; struct ord a;C.struct ordint x; int y; int z;
6、 a;D.structint x; int y; int z; a;16.以下程序段中,与语句 k=ab? (be? 1:0):0;功能相同的是(分数:1.00)A.if(ab) else k=0;B.if(ab)|(be) k=1;else k=0;C.if(a=b) k=0;else if(b=c) k=1;D.if(ab) k=1;else if(bc) k=1;else k=0;17.下列关于 C 语言文件的叙述中,正确的是(分数:1.00)A.文件由一系列数据依次排列组成,只能构成二进制文件B.文件由结构序列组成,可以构成二进制文件或文本文件C.文件由数据序列组成,可以构成二进制文件
7、或文本文件D.文件由字符序列组成,其类型只能是文本文件18.以下程序运行后的输出结果是#include#includemain()char str20=One * World“, “One * Dream!“, *p=str1;printf(“%d,“, strlen(p); printf(“%s/n“, p);(分数:1.00)A.9,One * WorldB.9,One * DreamC.10,One * Dream!D.10,One * World19.以下程序运行后的输出结果是#includestdio.hint f(int n);main()int a=3, s;s=f((分数:1.
8、00)A.; s=s+f(a); pri20.下列函数的功能是fun(char *a, char *b)while(*b=*(分数:1.00)_21.阅读以下程序#includestdio.hmain()int case; float printF;printf(“请输入 2 个数:“);scanf(“%d %f“, printf(“%d %f/n“, case, printF);该程序编译时产生错误,其出错原因是(分数:2.00)A.定义语句出错,case 是关键字,不能用作用户自定义标识符B.定义语句出错,printF 不能用作用户自定义标识符C.定义语句无错,scanf 不能作为输入函数
9、使用D.定义语句无错,printf 不能输出 case 的值22.已知字母 A 的 ASCII 码为 65,以下程序运行后的输出结果是#includestdio.hmain()char c1, c2;c1=A+8-4;c2=A+8-5;printf(“%c, %d/n“, c1, c2);(分数:2.00)A.E,68B.D,69C.E,DD.输出无定值23.下列有关 C 语言字符数组的叙述中,错误的是(分数:2.00)A.不可以用赋值语句给字符数组名赋字符串B.可以用输入语句把字符串整体输入给字符数组C.字符数组中的内容不一定是字符串D.字符数组只能存放字符串24.对于循环队列,下列叙述中正
10、确的是(分数:2.00)A.队头指针是固定不变的B.队头指针一定大于队尾指针C.队头指针一定小于队尾指针D.队头指针可以大于队尾指针,也可以小于队尾指针25.软件设计中划分模块的一个准则是(分数:2.00)A.低内聚、低耦合B.高内聚、低耦合C.低内聚、高耦合D.高内聚、高耦合26.若有定义语句:int x=10;,则表达式 x-=x+x 的值为(分数:2.00)A.-20B.-10C.0D.1027.设有定义:char *c;,以下选项中能够使字符型指针 c 正确指向一个字符串的是(分数:2.00)A.char str=“string“; c=str;B.scanf(“%s“,c);C.c=
11、getchar();D.*c=“string“;28.表达式:(int)(double)9/2)-(9)%2 的值是(分数:2.00)A.0B.3C.4D.529.以下程序运行后的输出结果是#includevoid fun(int P)int d=2;P=d+; printf(“%d“, P);main()int a=1;fun((分数:2.00)A.; printf(“%d/30.以下程序运行后的输出结果是#includestdio.hmain()int a=1, b=0;print(“%d,“, b=a+b);printf(“%d/n“, a=2*b);(分数:2.00)A.0,0B.1,
12、0C.3,2D.1,231.有 3 个关系 R、S 和 T 如下:(分数:2.00)A.B.C.D.32.以下程序运行后的输出结果是#includemain()int m=1, n=2, *P=r=P; p=q; q=r;printf(“%d, %d, %d, %d/n“, m, n, *p, *q);(分数:2.00)A.1,2,1,2B.1,2,2,1C.2,1,2,1D.2,1,1,233.以下程序运行后的输出结果是#includestdio.h#includestring.hmain()char a10=“abed“;printf(“%d, %d/n“, strlen((分数:2.00
13、)A., sizeof(a);34.以下程序运行后的输出结果是#includestdio.hmain()char s=“012xy“; int i, n=0;for(i=0; si!=0; i+)if(si=a printf(“%d/n“, n);(分数:2.00)A.0B.2C.3D.535.以下选项中,能用作用户标识符的是(分数:2.00)A.voidB.8_8C._0_D.unsigned36.以下程序运行后的输出结果是#includestdio.hmain()int n=2, k=0;while(k+ printf(“%d %d/n“, k, n);(分数:2.00)A.0 2B.1
14、3C.5 7D.1 237.以下程序运行后的输出结果是#includestdio.hmain()int c=0, k;for(k=1; k3; k+)switch(k)default: c+=k;case 2: c+; break; case 4: c+=2; break;printf(“%d/n“, c);(分数:2.00)A.3B.5C.7D.938.以下程序运行后的输出结果是#includestdio.h#includestring.hstruct Aint a; char b10; double c; ;struct A f(struct A t);main()struct A a=1
15、001, “ZhangDa“, 1098.0;a=f((分数:2.00)A.; printf(“%d, %s, %6.1f/n“, a.a, a.b, a.c);struct A f(st39.下列数据结构中,属于非线性结构的是(分数:2.00)A.循环队列B.带链队列C.二叉树D.带链栈40.设有定义:int a=1,b=2,e=3;,以下语句中执行效果与其他 3 个不同的是(分数:2.00)A.if(ab) c=a, a=b, b=c;B.if(ab) c=a, a=b, b=c;C.if(ab) c=a; a=b; b=c;D.if(ab) c=a; a=b; b=e;二、填空题(总题数
16、:15,分数:30.00)41.某二叉树有 5 个度为 2 的结点及 3 个度为 1 的结点,则该二叉树中共有 1 个点。(分数:2.00)填空项 1:_42.程序流程图中的菱形框表示的是 1。(分数:2.00)填空项 1:_43.软件开发过程主要分为需求分析、设计、编码和测试 4 个阶段,其中 1 阶段产生“软件需求规格说明书”。(分数:2.00)填空项 1:_44.在数据库技术中,实体集之间的联系可以是一对一或一对多或多对多的,那么“学生”和“可选课程”的联系为 1。(分数:2.00)填空项 1:_45.人员基本信息一般包括:身份证号、姓名、性别、年龄等。其中可以作为主关键字的是 1。(分
17、数:2.00)填空项 1:_46.若有定义语句:int a=5;,则表达式 a+的值是 1。(分数:2.00)填空项 1:_47.若有语句 double x=17; int y;,当执行 y=(int)(x/5)%2;之后 y 的值为 1。(分数:2.00)填空项 1:_48.以下程序运行后的输出结果是_。#includestdio.hmain()int x=20;printf(“%d“, 0x20);printf(“%d/n“, 0x (分数:2.00)填空项 1:_49.以下程序运行后的输出结果是_。#includestdio.hmain()int a=1, b=7;do b=b/2; a
18、+=b;while(b1);printf(“%d/n“, a);(分数:2.00)填空项 1:_50.以下程序运行后的输出结果是_。#includestdio.hmain()int f, f1, f2, i; f1=0; f2=1;printf(“%d %d“, f1, f2);for(i=3; i=5; i+)f=f1+f2; printf(“%d“, f);f1=f2; f2=f;printf(“/n“);(分数:2.00)填空项 1:_51.以下程序运行后的输出结果是_。#includestdio.hint a=5;void fun(int b)int a=10; a+=b; print
19、f(“%d“, a);main()int c=20;fun(c); a+=c; printf(“%d/n“, a);(分数:2.00)填空项 1:_52.设有定义:struct personint ID; char name12; P;请将 scanf(“%d“, _);语句补充完整,使其能够为结构体变量 P 的成员 ID 正确读入数据。(分数:2.00)填空项 1:_53.以下程序运行时从键盘输入:How are you? 回车,则输出结果为_。#includestdio.hmain()char a20=“How are you?“,b20;scanf(“%s“, b); printf(“%
20、s %s/n“, a, b);(分数:2.00)填空项 1:_54.以下程序运行后的输出结果是_。#includestdio.htypedef structint num; double s; REC;void fun1(REC x)x.num=23; x.s=88.5;main()REC a=16, 90.0;fun1(a);printf(“%d/n“, a.num);(分数:2.00)填空项 1:_55.以下程序运行后的输出结果是_。#includestdio.hfun(int x)if(x/20) fun(x/2);printf(“%d“, x);main()fun(6); printf
21、(“/n“);(分数:2.00)填空项 1:_二级 C 语言笔试-102 答案解析(总分:100.00,做题时间:90 分钟)一、选择题(总题数:40,分数:70.00)1.以下函数 findmax 拟实现在数组中查找最大值并作为函数值返回,但程序中有错导致不能实现预定功能,造成错误的原因是#define MIN -2147483647int findmax (int X, int n)int i, max;for(i=0; in; i+)max=MIN;if(maxxi) max=xi;return max;(分数:2.00)A.定义语句 int i, max; 中 max 未赋初值B.赋值
22、语句 max=MIN;中,不应给 max 赋 MIN 值C.语句 if(maxxi) max=xi;中判断条件设置错误D.赋值语句 max=MIN;放错了位置 解析:解析 程序中 max=MIN;应该放在 for 循环语句之前,否则每次循环都要将 MIN 的值重新赋给max,这样不能实现求最大值的算法思想。2.数据库管理系统是(分数:2.00)A.操作系统的一部分B.在操作系统支持下的系统软件 C.一种编译系统D.一种操作系统解析:解析 数据库管理系统是指位于用户与操作系统之间的数据管理软件。数据库管理系统是为数据库建立、使用和维护而配置的软件。3.下列叙述中正确的是(分数:2.00)A.程序
23、设计的任务就是编写程序代码并上机调试B.程序设计的任务就是确定所用数据结构C.程序设计的任务就是确定所用算法D.以上 3 种说法都不完整 解析:解析 选项 A、B、C 的说法都不完整。程序设计应根据计算机要完成的任务进行数据结构和算法的设计,并且编写其程序代码,然后进行调试,直到得出正确结果。4.软件详细设计产生的图如图所示,该图是(分数:2.00)A.B.C. D.解析:解析 N-S 图是由若干基本框图构成的流程图,其特点是没有流程线;PAD(问题分析图,Problem Analysis Diagram)是一种由左往右展开的二维树状结构;程序流程图用于描述问题解决的过程和步骤,其中方框表示处
24、理步骤,菱形框表示逻辑判断,箭头表示控制流向;E-R 图即实体一联系图(Entity Relationship Diagram),用来描述现实世界的概念模型,构成元素有实体、属性和联系,分别用矩形、椭圆形和菱形表示。5.以下程序运行后的输出结果是#includestdio.hmain()int a=2, 3, 5, 4, i;for(i=0; i4; i+)switch(i%2)case 0: switch(ai%2)case 0:ai+: break;case 1: ai-;break;case i: ai=0;for(i=0; i4; i+) printf(“%d“, ai); print
25、f(“/n“);(分数:2.00)A.3 3 4 4B.2 0 5 0C.3 0 4 0 D.0 3 0 4解析:解析 程序执行过程及其取值参见下表。*所以,程序最后输出 a 数组中的值分别为 3040。6.有以下定义语句,编译时会出现编译错误的是(分数:2.00)A.char a=a;B.char a=/n;C.char a=aa; D.char a=/x2d;解析:解析 字符变量只能存放一个字符,字符常量可以用来给字符变量赋值。C 语言规定字符常量是用一对单撇号“”括起来的单个字符。在选项 C 中,单撇号中有两个字符。7.下列数据结构中,能够按照“先进后出”原则存取数据的是(分数:2.00
26、)A.循环队列B.栈 C.队列D.二叉树解析:解析 栈是限定只在一端进行插入与删除的线性表,通常称进行插入、删除的这一端为栈顶,另一端为栈底。栈顶元素总是后被插入的元素,也是最先被删除的元素;栈底元素总是最先被插入的元素,也是最后才能被删除的元素。栈是按照“先进后出”或“后进先出”的原则组织数据的。8.以下程序段的输出结果是int r=8;printf(“%d/n“, r 1);(分数:2.00)A.16B.8C.4 D.2解析:解析 变量 r 的值为 8,其二进制为 00001000,右移 1 位后为 00000100,即十进制数 4,所以输出结果为 4。9.设有以下函数void fun(i
27、nt n, char *s) 则下面对函数指针的定义和赋值均正确的是(分数:2.00)A.void(*pf)(); pf=fun; B.viod *pf(); pf=fun;C.void *pf(); *pf=fun;D.void(*pf)(int, char); pf=解析:解析 选项 B、C 中的 pf 定义的不是可指向函数的指针。对于选项 D,赋值时 fun 前不应有s=f(a+1); t=f(a+1);printf(“%d, %d/n“, s, t);(分数:1.00)A.10,64 B.10,10C.64,10D.64,64解析:解析 s=f(a+1)=a+1*a+1*a+1=3+1
28、*3+1*3+1=10t=f(a+1)=(a+1)*(a+1)*(a+1)= =(3+1)*(3+1)*(3+1)=6414.下列选择项中不属于结构化程序设计原则的是(分数:1.00)A.可封装 B.自顶向下C.模块化D.逐步求精解析:解析 模块化、自顶向下、逐步求精都是结构化程序设计的原则;可封装是面向对象程序设计原则。15.下面结构体的定义语句中,错误的是(分数:1.00)A.struct ordint x; int y; int z; struct ord a;B.struct ordint x; int y; int z; struct ord a; C.struct ordint x
29、; int y; int z; a;D.structint x; int y; int z; a;解析:解析 对于选项 B,结构体类型声明和定义分开时,在声明后应有分号“;”。16.以下程序段中,与语句 k=ab? (be? 1:0):0;功能相同的是(分数:1.00)A.if(ab) else k=0; B.if(ab)|(be) k=1;else k=0;C.if(a=b) k=0;else if(b=c) k=1;D.if(ab) k=1;else if(bc) k=1;else k=0;解析:解析 语句 k=ab? (bc? 1:0):0;的功能是:当 ab 条件成立时,k 的值由(b
30、c? 1:0)确定,即当 ab 与 bc 同时成立时,k 值为 1,否则为 0;当 ab 条件不成立时,k 的值为 0。选项 A 与语句符合。对于选项 B、D,当 ab 或 bc,k 值为 1,与语句不符合。对于选项 c,当 b=c 时,k 值为 1,与语句不符合。17.下列关于 C 语言文件的叙述中,正确的是(分数:1.00)A.文件由一系列数据依次排列组成,只能构成二进制文件B.文件由结构序列组成,可以构成二进制文件或文本文件C.文件由数据序列组成,可以构成二进制文件或文本文件 D.文件由字符序列组成,其类型只能是文本文件解析:解析 文件由数据序列组成,可以构成二进制文件或文本文件。18.
31、以下程序运行后的输出结果是#include#includemain()char str20=One * World“, “One * Dream!“, *p=str1;printf(“%d,“, strlen(p); printf(“%s/n“, p);(分数:1.00)A.9,One * WorldB.9,One * DreamC.10,One * Dream! D.10,One * World解析:解析 初始化*p=str1使指针变量 p 指向第二个字符串“One * Dream!“,输出长度为 10。语句printf(“%s/n“, p);输出字符串“One * Dream!“。19.以
32、下程序运行后的输出结果是#includestdio.hint f(int n);main()int a=3, s;s=f((分数:1.00)A.; s=s+f(a); pri解析:解析 本题考查静态局部变量。第一次调用 f 函数时,将实参 a 值 3 传给形参变量 n,此时,静态局部变量 a 的值为 1,经过 n+=a+运算后,n 为 4,a 为 2,return 语句将 4 带回到 main 函数赋给 s;第二次调用 f 函数时,将实参 a 值 3(注意,实参 a 的值并未改变)传给变量 n,此时,静态局部变量 a 的值为 2,经过 n+=a+运算后,n 为 5,a 为 3,return 语
33、句将 5 带回到 main 函数,s=s+f(a)=4+5=9。20.下列函数的功能是fun(char *a, char *b)while(*b=*(分数:1.00)_解析:解析 (*b=*a)!=/0是将 a 所指空间的字符赋给 b 所指空间,所以,while(*b=*a)!=/0) a+, b+;21.阅读以下程序#includestdio.hmain()int case; float printF;printf(“请输入 2 个数:“);scanf(“%d %f“, printf(“%d %f/n“, case, printF);该程序编译时产生错误,其出错原因是(分数:2.00)A.定
34、义语句出错,case 是关键字,不能用作用户自定义标识符 B.定义语句出错,printF 不能用作用户自定义标识符C.定义语句无错,scanf 不能作为输入函数使用D.定义语句无错,printf 不能输出 case 的值解析:解析 该程序编译时出现语法错误:Declaration syntax error in function main。其错误原因是 case 是关键字,不能用作用户自定义标识符。22.已知字母 A 的 ASCII 码为 65,以下程序运行后的输出结果是#includestdio.hmain()char c1, c2;c1=A+8-4;c2=A+8-5;printf(“%c,
35、 %d/n“, c1, c2);(分数:2.00)A.E,68 B.D,69C.E,DD.输出无定值解析:解析 c1=A+8-4=A+4=E, c2=A+8-5=A+3=D(ASCII 码为 68),所以程序运行结果为 E,68。23.下列有关 C 语言字符数组的叙述中,错误的是(分数:2.00)A.不可以用赋值语句给字符数组名赋字符串B.可以用输入语句把字符串整体输入给字符数组C.字符数组中的内容不一定是字符串D.字符数组只能存放字符串 解析:解析 数组名是地址常量,所以不能用赋值语句给字符数组名赋字符串;可以用输入语句把字符串以整体输入方式给字符数组赋值;字符数组中的内容不一定是字符串,可
36、以是整型数。24.对于循环队列,下列叙述中正确的是(分数:2.00)A.队头指针是固定不变的B.队头指针一定大于队尾指针C.队头指针一定小于队尾指针D.队头指针可以大于队尾指针,也可以小于队尾指针 解析:解析 循环队列是将顺序队列首尾相连形成的,随着插入元素或删除元素的进行,其队头指针及队尾指针是在不断变化的,有时可能会出现队头指针大于队尾指针的情况,也可能是队尾指针大于队头指针。25.软件设计中划分模块的一个准则是(分数:2.00)A.低内聚、低耦合B.高内聚、低耦合 C.低内聚、高耦合D.高内聚、高耦合解析:解析 模块划分应考虑的因素包括模块之间的耦合和内聚。一般来说,要求模块之间的耦合尽
37、可能低,即模块尽可能独立;要求模块的内聚程度尽可能高,即遵循高内聚、低耦合的原则。26.若有定义语句:int x=10;,则表达式 x-=x+x 的值为(分数:2.00)A.-20B.-10 C.0D.10解析:解析 表达式 x-=x+x 等价于 x=x-(x+x)=10-20=-10。27.设有定义:char *c;,以下选项中能够使字符型指针 c 正确指向一个字符串的是(分数:2.00)A.char str=“string“; c=str; B.scanf(“%s“,c);C.c=getchar();D.*c=“string“;解析:解析 对于选项 B,C 没有指向,编译会报警告错。对于选
38、项 C,c 只能被地址赋值,不能被getchar 读取的字符赋值。对于选项 D,赋值错误,应该改为 c=“string“;。28.表达式:(int)(double)9/2)-(9)%2 的值是(分数:2.00)A.0B.3 C.4D.5解析:解析 (int)(double)9/2)=4,(9)%2=1,所以(int)(double)9/2)-(9)%2=4-1=3。29.以下程序运行后的输出结果是#includevoid fun(int P)int d=2;P=d+; printf(“%d“, P);main()int a=1;fun((分数:2.00)A.; printf(“%d/解析:解析
39、 调用函数 fun 时将变量 a 的值 1 传给形参变量 p,p=d+将 2 赋给 p,再执行 d+;在函数fun 中,printf(“%“, p);输出 p 的值 2,main 函数中输出 a 的值 1。程序的输出结果为 21。30.以下程序运行后的输出结果是#includestdio.hmain()int a=1, b=0;print(“%d,“, b=a+b);printf(“%d/n“, a=2*b);(分数:2.00)A.0,0B.1,0C.3,2D.1,2 解析:解析 在第一个 printf 中计算了 b=a+b,使 b 值变为 1;在第二个 printf 中计算 a=2 *b=2
40、*1,a值变为 2。所以输出结果为“1,2”。31.有 3 个关系 R、S 和 T 如下:(分数:2.00)A.B.C.D. 解析:解析 两个相同结构的关系的并是由属于这两个关系的元组组成的集合。32.以下程序运行后的输出结果是#includemain()int m=1, n=2, *P=r=P; p=q; q=r;printf(“%d, %d, %d, %d/n“, m, n, *p, *q);(分数:2.00)A.1,2,1,2B.1,2,2,1 C.2,1,2,1D.2,1,1,2解析:解析 执行语句 r=p; p=q; q=r;后,改变了 p、q 的指向,即 p 指向了 n,q 指向了
41、 m,m 和 n 的值没有改变,分别仍为 1 和 2。33.以下程序运行后的输出结果是#includestdio.h#includestring.hmain()char a10=“abed“;printf(“%d, %d/n“, strlen((分数:2.00)A., sizeof(a);解析:解析 strlen 是求 a 数组中字符串的实际长度(不含串结束符),结果为 4;sizeof 是求 a 数组的定义长度(加上/0所占的一个字节),结果为 10。34.以下程序运行后的输出结果是#includestdio.hmain()char s=“012xy“; int i, n=0;for(i=0
42、; si!=0; i+)if(si=a printf(“%d/n“, n);(分数:2.00)A.0B.2 C.3D.5解析:解析 程序的功能是统计字符串“012xy”中小写字母的个数。所以程序的运行结果为 2。35.以下选项中,能用作用户标识符的是(分数:2.00)A.voidB.8_8C._0_ D.unsigned解析:解析 C 语言用户标识符可以由字母、数字和下画线组成,且第一个字符不能是数字。选项 B 的第一个字母不合法;关键字不能用作用户标识符,选项 A、D 不合法。36.以下程序运行后的输出结果是#includestdio.hmain()int n=2, k=0;while(k+
43、 printf(“%d %d/n“, k, n);(分数:2.00)A.0 2B.1 3C.5 7D.1 2 解析:解析 while 循环条件是 k+ for(k=1; k3; k+)switch(k)default: c+=k;case 2: c+; break; case 4: c+=2; break;printf(“%d/n“, c);(分数:2.00)A.3 B.5C.7D.9解析:解析 for 循环 2 次:当循环变量 k=1 时,从 default 入口,执行 c+=k;,再顺序执行c+;,break 跳出 switch 结构,此时 c 的值为 2;当循环变量 k=2 时,从 ca
44、se 2 入口,执行c+;,break 跳出 switch 结构,此时 c 的值为 3;退出循环结构,输出 c 值 3。38.以下程序运行后的输出结果是#includestdio.h#includestring.hstruct Aint a; char b10; double c; ;struct A f(struct A t);main()struct A a=1001, “ZhangDa“, 1098.0;a=f((分数:2.00)A.; printf(“%d, %s, %6.1f/n“, a.a, a.b, a.c);struct A f(st解析:解析 函数调用 f(a)将结构体变量
45、a 的值传给 f 函数的形参 t,在函数 f 中改变了 t 的值,通过return 语句返回后,在 main 函数中,因为 a=f(a);,a 也被改变,所以最后输出的是改变后的结果。39.下列数据结构中,属于非线性结构的是(分数:2.00)A.循环队列B.带链队列C.二叉树 D.带链栈解析:解析 根据数据结构中各数据元素之间前后关系的复杂程度,一般将数据结构分为两大类:线性结构与非线性结构。线性结构表示数据元素之间为一对一的关系,非线性结构表示数据元素之间为一对多或者多对一的关系。根据各种结构的定义可知二又树是一种非线性结构。40.设有定义:int a=1,b=2,e=3;,以下语句中执行效
46、果与其他 3 个不同的是(分数:2.00)A.if(ab) c=a, a=b, b=c;B.if(ab) c=a, a=b, b=c;C.if(ab) c=a; a=b; b=c; D.if(ab) c=a; a=b; b=e;解析:解析 选项 A,if 子句是一个逗号表达式,其效果与选项 B 和 D 相同,即当 ab 成立时,执行c=a; a=b; b=c;语句,否则不执行。选项 C 中,当 ab 成立时,执行 c=a;后,再顺序地执行 a=b; b=c;,与选项 A、B、D 相同;但当 ab 不成立时,仍要执行 a=b; b=c; 语句,与选项 A、B、D 不同。二、填空题(总题数:15,分数:30.00)41.某二叉树有 5 个度为 2 的结点及 3 个度为 1 的结点,则该二叉树中共有 1 个点。(分数:2.00)填空项 1:_ (正确答案:14)解析:解析 在二叉树中,度为 0 的结点数是度为 2 的结点数加 1,故二叉树中结点数的总和为度为 0的结点数、度为 1 的结点数及度为 2 的结点数三者相加,得出结果为 14 个结点。42.程序流程图中的菱形框表示的是 1。(分数:2.00)填空项 1:_ (正确