1、二级 C语言笔试-27 及答案解析(总分:100.00,做题时间:90 分钟)一、选择题(总题数:40,分数:70.00)1.以下选项中合法的标识符是(分数:2.00)A.1_1B.1-1C._11D.1_2.以下程序运行后的输出结果是#includestdio.hmain()int a=5, b=1, t;t=(a2)|b); printf(“%d/n“, t);(分数:2.00)A.21B.11C.6D.13.以下是 if语句的基本形式:if(表达式)语句其中“表达式”(分数:2.00)A.必须是逻辑表达式B.必须是关系表达式C.必须是逻辑表达式或关系表达式D.可以是任意合法的表达式4.以
2、下程序运行后的输出结果是#includestdio.hviod f(int *p, int *q);main()int m=1, n=2, *r=f(r, printf(“%d, %d“, m, n);void f(int *p, int *q)P=p+1; *q=*q+1; (分数:2.00)A.1,3B.2,3C.1,4D.1,25.以下选项中,能用作数据常量的是(分数:2.00)A.o115B.0118C.1.5e1.5D.115L6.设有定义:char s81; int i=10;,以下不能将一行(不超过 80个字符)带有空格的字符串正确读入的语句或语句组是(分数:2.00)A.get
3、s(s);B.while(si+=getchar()!=/n); si=/0;C.scanf(“%s“, s);D.do scanf(“%C“, while(si+!=/n); s=/0;7.以下程序运行后的输出结果是#includestdio.hmain()int a=1, b=2, C=3, d=0;if(a=1 else printf(%d, %d, %d/n“, a, b, C);else printf(“%d, %d, %d/n“, a, b, C);(分数:2.00)A.1,2,3B.1,3,2C.1,3,3D.3,2,18.支持子程序调用的数据结构是(分数:2.00)A.栈B.树
4、C.队列D.二叉树9.程序段:int x=12; double y=3.141593; printf(“%d%8.6f“, x, y);的输出结果是(分数:2.00)A.123.141593B.12 3.141593C.12,3.141593D.123.14159310.将 E-R图转换为关系模式时,实体和联系都可以表示为(分数:2.00)A.属性B.键C.关系D.域11.若函数中有定义语句:int k;,则(分数:1.00)A.系统将自动给 k赋初值 0B.这时 k中值无定义C.系统将自动给 k赋初值-1D.这时 k中无任何值12.下列叙述中错误的是(分数:1.00)A.软件测试的目的是发现
5、错误并改正错误B.对被调试的程序进行“错误定位”是程序调试的必要步骤C.程序调试通常也称为 DebugD.软件测试应严格执行测试计划,排除测试的随意性13.若有定义语句:double x,y, *px, *py;,执行了 px=之后,正确的输入语句是(分数:1.00)A.scanf(“%f%f“, x, y);B.scanf(“%f%f, C.scanf(“%lf%le“, px, py);D.scanf(“%lf%lf“, x, y);14.下列叙述中正确的是(分数:1.00)A.栈是“先进先出”的线性表B.队列是“先进先出”的线性表C.循环队列是非线性结构D.有序性表既可以采用顺序存储结构
6、,也可以采用链式存储结构15.耦合性和内聚性是对模块独立性度量的两个标准。下列叙述中正确的是(分数:1.00)A.提高耦合性、降低内聚性有利于提高模块的独立性B.降低耦合性、提高内聚性有利于提高模块的独立性C.耦合性是指一个模块内部各个元素间彼此结合的紧密程度D.内聚性是指模块间互相连接的紧密程度16.若文本文件 filea.txt中原有内容为:hello,则运行以下程序后,文件 filea.txt中的内容为#includestdio.hmain()EILE *f;f=fopen(“filea.txt“, “w“);fprintf(f, “abc“);fclose(f);(分数:1.00)A.
7、helloabcB.abcloC.abcD.abchello17.以下程序运行后的输出结果是#includestdio.hvoid fun(int *a, int *b)int *c;c=a; a=b; b=c;main()int x=3, y-5, *p=fun(p, q); printf(“%d, %d,“, *p, *q);fun( printf(“%d, %d/n“, *p, *q);(分数:1.00)A.3,5,5,3B.3,5,3,5C.5,3,3,5D.5,3,5,318.有两个关系 R、S 如下:(分数:1.00)A.B.C.D.19.若有以下定义,则对 x数组元素的正确应用是
8、int x10, *pt=x;(分数:1.00)A.*else return(x+y)/2);main()int a=4, b=5, c=6;printf(“%d/n“, fun(2*a, fun(b, c);(分数:2.00)A.3B.6C.8D.1222.设有定义:int x=2;,以下表达式中,值不为 6的是(分数:2.00)A.x*=x+1B.x+, 2*xC.x*=(1+x)D.2*x, x+=223.已知字母 a的 ASCII码值为 97,则以下程序运行后的输出结果是#includestdio.hvoid fun(char *s)while(*s)if(*s%2=0) printf
9、(“%C“, $s);s+;main()char a=“good“;fun((分数:2.00)A.; printf(“/n“)24.设有宏定义:#include IsDIV(k, n)(k%n=1) ? 1:0)且变量 m已正确定义并赋值,则宏调用:IsDIV(m, 5) main()int a=3, b=4, c=5, d;d=f(f(a, b), f(a, c);printf(“%d/n“, d);(分数:2.00)A.10B.9C.8D.726.已知字母 A的 ASCII码值为 65。以下程序运行后的输出结果是#includestdio.hmain()char *s=“ABC“;do p
10、rintf(“%d“, *s%10); s+;while(*s);(分数:2.00)A.5670B.656667C.567D.ABC27.设变量已正确定义,以下不能统计出一行中输入字符个数(不包含回车符)的程序段是(分数:2.00)A.n=0; while( ch=getchar()!=/n) n+;B.n=0; while( getchar()! =/n) n+;C.for( n=0; getehar()!=/n; n+);D.n=0; for( ch=getchar(); ch!=/n; n+);28.设函数中有整型变量 n,为保证其在未赋值的情况下初值为 0,应选择的存储类别是(分数:2
11、.00)A.autoB.registerC.staticD.auto或 register29.以下选项中正确的语句组是(分数:2.00)A.char s; s=“BOOK!“;B.char *s; s=“BOOK!“;C.char s10; s=“BOOK!“;D.char *s; s=“BOOK!“;30.有以下程序,若想通过键盘输入,使得 a1的值为 12,a2 的值为 34,c1 的值为字符 a,c2 的值为字符b,程序输出结果是:12,a,34,b。则正确的输入格式是(选项中的 代表空格,CR代表回车)#includestdio.hmain()int a1, a2; char c1,
12、c2;scanf(“%d %c%d%c“, printf(“%d, %c, %d, %c, a1, c1, a2, c2);(分数:2.00)A.B.C.D.31.以下程序运行后的输出结果是#includestdio.hstruct ordint x, y; dt2=1, 2, 3, 4;main()struct ord *P=dt;printf(“%d,“, +p-x); printf(“%d/n“, +p-y);(分数:2.00)A.1,2B.2,3C.3,4D.4,132.以下程序中的变量已正确定义,程序段的输出结果是for(i=0; i4; i+, i+)for(k=1; k3; k+
13、); printf(“*“);(分数:2.00)A.*B.*C.*D.*33.软件按功能可以分为应用软件、系统软件和支撑软件(或工具软件)。下面属于应用软件的是(分数:2.00)A.编译软件B.操作系统C.教务管理系统D.汇编程序34.数据库应用系统中的核心问题是(分数:2.00)A.数据库设计B.数据库系统设计C.数据库维护D.数据库管理员培训35.以下程序运行后的输出结果是#includestdio.hmain()char *a=“abcd“, “ef“, “gh“, “ijk“; int i;for(i=0; i4; i+) printf(“%c“, *ai);(分数:2.00)A.ae
14、giB.dfhkC.abcdD.abcdefghijk36.以下程序运行时,输入的值在哪个范围才会有输出结果?#includestdio.hmain()int x;Scanf(“%d“, if(x=3); elseif(x!=10) printf(“%d/n“, x);(分数:2.00)A.不等于 10的整数B.大于 3且不等于 10的整数C.大于 3或等于 10的整数D.小于 3的整数37.以下程序运行后的输出结果是#includestdio.h#define PT 3.5;#define S(x) PT*x*x;main()int a=1, b=2; printf(“%4.1f/n“, S
15、(a+b); (分数:2.00)A.14.0B.31.5C.7.5D.程序有错,无输出结果38.以下程序运行后的输出结果是#includestdio.hint b=2;int fun(int *k)b=*k+b; return(b);main()int a10=1, 2, 3, 4, 5, 6, 7, 8, i;for(i=2; i4; i+)b=fun( printf(“%d“, b);printf(“/n“);(分数:2.00)A.10 12B.8 10C.10 28D.10 1639.下列排序方法中,最坏情况下比较次数最少的是(分数:2.00)A.冒泡排序B.简单选择排序C.直接插入排序
16、D.堆排序40.以下函数按每行 8个输出数组中的数据,下画线处应填入的语句是void fun(int *w, int n)int i; for(i=0; in; i+)printf(“%d“, wi);printf(“/n“);(分数:2.00)A.if(i/8=0) print(“/n“);B.if(i/8=0) continue;C.if(i%8=0) print(“/n“);D.if(i%8=0) continue;二、填空题(总题数:15,分数:30.00)41.假设一个长度为 50的数组(数组元素的下标从 049)作为栈的存储空间,栈底指针 bottom指向栈底元素,栈顶指针 top
17、指向栈顶元素,如果 bottom=49,top=30(数组下标),则栈中具有 1 个元素。(分数:2.00)填空项 1:_42.软件测试可分为白盒测试和黑盒测试。基本路径测试属于 1 测试。(分数:2.00)填空项 1:_43.符合结构化原则的 3种基本控制结构是选择结构、循环结构和 1。(分数:2.00)填空项 1:_44.数据库系统的核心是 1。(分数:2.00)填空项 1:_45.在 E-R图中,图形包括矩形框、菱形框、椭圆框。其中表示实体联系的是 1 框。(分数:2.00)填空项 1:_46.表达式(int)(double)(5/2)+2.5)的值是 1。(分数:2.00)填空项 1:
18、_47.若变量 x、y 已定义为 int类型且 x的值为 99,y 的值为 9,请将输出语句 printf( 1, x/y);补充完整,使其输出的计算结果形式为:x/y=11。(分数:2.00)填空项 1:_48.以下程序运行输入 65回车后,能否输出结果、结束运行(请回答能或不能)_。#includestdio.hmain()char c1, c2;scanf(“%c“, while(c165 | c190) scanf(“%c“, c2=c1+32;printf(“(分数:2.00)填空项 1:_49.以下程序运行后的输出结果是_。#includestdio.hmain()int k=1,
19、 s=0;doif(k%2)!=0) continue;s+=k; k+;while(k10);printf(“s=%d/n“, s);(分数:2.00)填空项 1:_50.下列程序运行时,若输入 1abcedf2df回车,则输出结果为_。#includestdio.hmain()char a=0, ch;while(ch=getchar()!=/n)if(a%2!=0 a+; putchar(ch);printf(“/n“);(分数:2.00)填空项 1:_51.以下程序运行后的输出结果是_。#includestdio.hvoid fun(int *a)a0=a1; main()int a1
20、0=10, 9, 8, 7, 6, 5, 4, 3, 2, 1, i;for(i=2; i=0; i-) fun(for(i=0; i10; i+) printf(“%d“, ai);printf(“/n“);(分数:2.00)_52.请将以下程序中的函数声明语句补充完整。#includestdio.hint _;main()int x, y, (*P)();scanf(“%d%d“, p=max;printf(“%d/n“, (*P)(x, y);int max(int a, int b)return(ab ? a:b);(分数:2.00)填空项 1:_53.以下程序用来判断指定文件是否能正
21、常打开。请填空。#includestdio.hmain()FILE *fp;if(fp=fopen(“test.txt“, “r“)=_)printf(“未能打开文件!/n“);else printf(“文件打开成功!/n“);(分数:2.00)填空项 1:_54.程序运行的结果为_。#includestdio.h#includestring.hstruct Aint a; char b10; double c; ;void f(struct A *t);main()struct A a=1001, “ZhangDa“, 1098.0;f( printf(“%d, %s, %6.1f/n“,
22、a.a, a.b, a.c);void f(struct A *t) strcpy(t-b, “ChangRong“);(分数:2.00)填空项 1:_55.以下程序把 3个 NODETYPE型的变量链接成一个简单的链表,并在 while循环中输出链表结点数据域中的数据。请填空。#includestdio.hstruct nodeint data; struct node *next; ;typedef struct node NODETYPE;main()NODETYPE a, b, c, *h, *p; a.data=10; b.data=20; c.data=30; h=b.next=b
23、.next=c.next=/0;p=h;while(p)printf(“%d“, p-data);_;(分数:2.00)填空项 1:_二级 C语言笔试-27 答案解析(总分:100.00,做题时间:90 分钟)一、选择题(总题数:40,分数:70.00)1.以下选项中合法的标识符是(分数:2.00)A.1_1B.1-1C._11 D.1_解析:解析 C 语言中的用户标识符可以由字母、数字和下画线组成,且第一个字符不能是数字。选项A、D 第一个字母不符合语法要求,选项 B中“-”是非法字符。2.以下程序运行后的输出结果是#includestdio.hmain()int a=5, b=1, t;t
24、=(a2)|b); printf(“%d/n“, t);(分数:2.00)A.21 B.11C.6D.1解析:解析 将 5变换为二进制数为 101,左移 2位后为 10100;将 1转换为二进制数为 00001;将10100与 00001进行按位或运算后为 10101,再将其转换为十进制数为 21。3.以下是 if语句的基本形式:if(表达式)语句其中“表达式”(分数:2.00)A.必须是逻辑表达式B.必须是关系表达式C.必须是逻辑表达式或关系表达式D.可以是任意合法的表达式 解析:解析 C 语言中,if 语句中的控制表达式可以是任意合法的表达式。如果表达式的取值为 0,则表示不满足条件;如果
25、表达式的取值为非 0,则表示满足条件。4.以下程序运行后的输出结果是#includestdio.hviod f(int *p, int *q);main()int m=1, n=2, *r=f(r, printf(“%d, %d“, m, n);void f(int *p, int *q)P=p+1; *q=*q+1; (分数:2.00)A.1,3 B.2,3C.1,4D.1,2解析:解析 在 f函数中,p=p+1;的操作改变的是 p的指向;而*q=*q+1;的操作,将 q所指向存储单元 n中的值加 1,即 m的值不变,仍为 1,而 n的值变为 3。5.以下选项中,能用作数据常量的是(分数:2
26、.00)A.o115B.0118C.1.5e1.5D.115L 解析:解析 对于选项 A,“o”不符合语法要求;对于选项 B,以 0开头代表八进制整型常量,但其后面的数字中又出现了非八进制数字 8,出错;对于选项 C,用指数形式表示实型常量,e 后面的指数部分必须为整型数,出错;对于选项 D,整数后面加字母 L是长整型常量的表示形式。6.设有定义:char s81; int i=10;,以下不能将一行(不超过 80个字符)带有空格的字符串正确读入的语句或语句组是(分数:2.00)A.gets(s);B.while(si+=getchar()!=/n); si=/0;C.scanf(“%s“,
27、s); D.do scanf(“%C“, while(si+!=/n); s=/0;解析:解析 在 scanf中,采用“%s”格式符将整个字符串一次输入,直到遇到空格或制表符为止。对于选项 C,不能正确读入带有空格的字符串。7.以下程序运行后的输出结果是#includestdio.hmain()int a=1, b=2, C=3, d=0;if(a=1 else printf(%d, %d, %d/n“, a, b, C);else printf(“%d, %d, %d/n“, a, b, C);(分数:2.00)A.1,2,3B.1,3,2C.1,3,3 D.3,2,1解析:解析 第一条 i
28、f语句的条件判断成立,并且执行 b+操作后,b 的值为 3;第二条 if语句判断,条件 b!=2的值为真,不再进行 c-!=3的判断,因此,c 未被改变,仍然为 3。8.支持子程序调用的数据结构是(分数:2.00)A.栈 B.树C.队列D.二叉树解析:解析 栈支持子程序调用。栈是一种只能在一端进行插入或删除的线性表。在主程序调用子程序时要首先保存主程序当前的状态,然后转去执行子程序,最终把子程序的执行结果返回到主程序中调用子程序的位置,继续向下执行,这种调用符合栈的特点。9.程序段:int x=12; double y=3.141593; printf(“%d%8.6f“, x, y);的输出
29、结果是(分数:2.00)A.123.141593 B.12 3.141593C.12,3.141593D.123.141593解析:解析 printf 函数的两个格式控制符之间没有空格和逗号,故选项 B、C 不正确;输出格式控制符%m.nf 表示指定输出的实型数据的宽度为 m(包含小数点)并保留 n位小数。当输出数据的小数位大于 n时,最后一位按照四舍五入进行截取;若输出数据的小数位小于 n时,在小数的最右边补 0;若给出的总宽度 m小于 n加上整数位数和小数点,则自动突破 m的限制;反之,数字右对齐,左边补空格。本题中3.141593数值长度为 8,小数位数为 6,因此左端没有空格。10.将
30、 E-R图转换为关系模式时,实体和联系都可以表示为(分数:2.00)A.属性B.键C.关系 D.域解析:解析 数据库逻辑设计的主要工作是将 E-R图转换成指定 RDBMS中的关系模式。从 E-R图到关系模式的转换是比较直接的,实体与联系都可以表示成关系,E-R 图中的属性也可以转换成关系的属性。实体集也可以转换成关系。11.若函数中有定义语句:int k;,则(分数:1.00)A.系统将自动给 k赋初值 0B.这时 k中值无定义 C.系统将自动给 k赋初值-1D.这时 k中无任何值解析:解析 函数中定义的变量,如果不专门声明,属于自动变量。自动变量不会自动赋初值,此时,变量中无确定值,称变量值
31、“无意义”。12.下列叙述中错误的是(分数:1.00)A.软件测试的目的是发现错误并改正错误 B.对被调试的程序进行“错误定位”是程序调试的必要步骤C.程序调试通常也称为 DebugD.软件测试应严格执行测试计划,排除测试的随意性解析:解析 软件测试的目的是暴露错误,评价程序的可靠性。软件调试的目的是发现错误的位置,并改正错误。软件测试和调试不是同一个概念。13.若有定义语句:double x,y, *px, *py;,执行了 px=之后,正确的输入语句是(分数:1.00)A.scanf(“%f%f“, x, y);B.scanf(“%f%f, C.scanf(“%lf%le“, px, py
32、); D.scanf(“%lf%lf“, x, y);解析:解析 scanf 函数的格式为:scanf(控制格式,地址表列)。其中,控制格式和地址表列之间用“,”分开,地址表列应为变量的地址。在选项 A、D 中,地址表列表示错误;选项 B中控制格式与地址表列之间缺少逗号。14.下列叙述中正确的是(分数:1.00)A.栈是“先进先出”的线性表B.队列是“先进先出”的线性表C.循环队列是非线性结构D.有序性表既可以采用顺序存储结构,也可以采用链式存储结构 解析:解析 栈是“先进后出”的线性表;队列是“先进先出”的线性表;循环队列是队列的一种顺序存储结构,因此是线性结构;有序线性表既可以采用顺序存储
33、结构,也可以采用链式存储结构。15.耦合性和内聚性是对模块独立性度量的两个标准。下列叙述中正确的是(分数:1.00)A.提高耦合性、降低内聚性有利于提高模块的独立性B.降低耦合性、提高内聚性有利于提高模块的独立性 C.耦合性是指一个模块内部各个元素间彼此结合的紧密程度D.内聚性是指模块间互相连接的紧密程度解析:解析 耦合性是模块间互相连接的紧密程度的度量,内聚性是一个模块内部各个元素间彼此结合的紧密程度的度量。较优秀的软件设计应尽量做到高内聚、低耦合,即减弱模块之间的耦合性和提高模块内的内聚性,这样有利于提高模块的独立性。16.若文本文件 filea.txt中原有内容为:hello,则运行以下
34、程序后,文件 filea.txt中的内容为#includestdio.hmain()EILE *f;f=fopen(“filea.txt“, “w“);fprintf(f, “abc“);fclose(f);(分数:1.00)A.helloabcB.abcloC.abc D.abchello解析:解析 “w“表示建立一个供写入的文件。如果文件不存在,则系统将用在 fopen调用中指定的文件名建立一个新文件;如果指定的文件已存在,则将从文件的起始位置开始写入,文件中原有的内容将全部消失。17.以下程序运行后的输出结果是#includestdio.hvoid fun(int *a, int *b)
35、int *c;c=a; a=b; b=c;main()int x=3, y-5, *p=fun(p, q); printf(“%d, %d,“, *p, *q);fun( printf(“%d, %d/n“, *p, *q);(分数:1.00)A.3,5,5,3B.3,5,3,5 C.5,3,3,5D.5,3,5,3解析:解析 fun 函数功能是改变指针变量 a和 b的指向,并不能改变 a和 b所指向存储空间的值。因此,第一个 printf语句的输出结果为“3,5”。第二个 printf语句的输出结果仍为“3,5”。18.有两个关系 R、S 如下:(分数:1.00)A.B. C.D.解析:解析
36、 专门的关系运算有 3种:投影、选择和连接。选择运算是从关系中找出满足给定条件的那些元组,其中的条件是以逻辑表达式给出的,值为真的元组将被选取,这种运算是从水平方向抽取元组的。投影运算是从关系模式中挑选若干属性组成新的关系,这是从列的角度进行的运算,相当于对关系进行垂直分解。连接运算是二目运算,需要两个关系作为操作对象。19.若有以下定义,则对 x数组元素的正确应用是int x10, *pt=x;(分数:1.00)A.*else return(x+y)/2);main()int a=4, b=5, c=6;printf(“%d/n“, fun(2*a, fun(b, c);(分数:2.00)A
37、.3B.6 C.8D.12解析:解析 将 a、b、c 的值代入 fun(2*4, fun(f(5, 6)中,f(5, 6)调用,返回值为 5;f(8, 5)调用,返回值为 6。22.设有定义:int x=2;,以下表达式中,值不为 6的是(分数:2.00)A.x*=x+1B.x+, 2*xC.x*=(1+x)D.2*x, x+=2 解析:解析 选项 A、C 均为 x=x(x+1)=23=6;对于选项 B,先执行 x+后,x 的值为 3,最后一个表达式 23=6的值是整个表达式的值;对于选项 D,2x=22,表达式的值为 4,但 x的值仍为 2,表达式 x+=2应为 x=2+2,值为 4。23.
38、已知字母 a的 ASCII码值为 97,则以下程序运行后的输出结果是#includestdio.hvoid fun(char *s)while(*s)if(*s%2=0) printf(“%C“, $s);s+;main()char a=“good“;fun((分数:2.00)A.; printf(“/n“) 解析:解析 fun 函数的功能是输出字符串中 ASCII码为偶数的字符。g 的 ASCII码为 103,o 的 ASCII码为 111,d 的 ASCII码为 100,输出字符 d。24.设有宏定义:#include IsDIV(k, n)(k%n=1) ? 1:0)且变量 m已正确定义
39、并赋值,则宏调用:IsDIV(m, 5) main()int a=3, b=4, c=5, d;d=f(f(a, b), f(a, c);printf(“%d/n“, d);(分数:2.00)A.10B.9 C.8D.7解析:解析 d=f(f(a, b),f(a, c);中,将 a、b、c 的值分别代入 f(a, b)和 f(a, c),d=f(f(3, 4),f(3, 5);。f(3, 4)调用,返回 3;f(3, 5)调用,返回 6;再进行 f(3, 6)调用,返回 9。26.已知字母 A的 ASCII码值为 65。以下程序运行后的输出结果是#includestdio.hmain()cha
40、r *s=“ABC“;do printf(“%d“, *s%10); s+;while(*s);(分数:2.00)A.5670B.656667C.567 D.ABC解析:解析 每进行一次循环,将输出 s指向字母的 ASCII码值除以 10的余数。字符 A的 ASCII码值是65,第一次输出 65%10的余数 5,执行 s+后,指针指向字母 B;第二次输出 66%10的余数 6,执行 s+后,指针指向字母 c;第三次输出 67%10的余数 7,执行 s+后,指针指向串结束标志“/0”。此时,*s 等于0,退出循环。因此,输出结果为 567。27.设变量已正确定义,以下不能统计出一行中输入字符个数
41、(不包含回车符)的程序段是(分数:2.00)A.n=0; while( ch=getchar()!=/n) n+;B.n=0; while( getchar()! =/n) n+;C.for( n=0; getehar()!=/n; n+);D.n=0; for( ch=getchar(); ch!=/n; n+); 解析:解析 选项 D中 ch=getchar()的操作,在 for语句中所处的位置决定了此操作仅做一次,即只能从键盘上接收一个字符。如果该字符是回车符,则只循环一次就退出;如果输入一个非回车字符,则程序进入无限循环。28.设函数中有整型变量 n,为保证其在未赋值的情况下初值为 0
42、,应选择的存储类别是(分数:2.00)A.autoB.registerC.static D.auto或 register解析:解析 在 C语言中,对于静态局部变量 static,编译时会自动给数值型变量赋初值 0或者给字符变量赋初值“/0”。29.以下选项中正确的语句组是(分数:2.00)A.char s; s=“BOOK!“;B.char *s; s=“BOOK!“;C.char s10; s=“BOOK!“;D.char *s; s=“BOOK!“; 解析:解析 数组名代表数组的首地址,是一个地址常量,不能对其赋值,所以选项 A、C 错误;只有在初始化时才可以用花括号,所以选项 B错误。3
43、0.有以下程序,若想通过键盘输入,使得 a1的值为 12,a2 的值为 34,c1 的值为字符 a,c2 的值为字符b,程序输出结果是:12,a,34,b。则正确的输入格式是(选项中的 代表空格,CR代表回车)#includestdio.hmain()int a1, a2; char c1, c2;scanf(“%d %c%d%c“, printf(“%d, %c, %d, %c, a1, c1, a2, c2);(分数:2.00)A. B.C.D.解析:解析 对于格式控制“%d%c%d%c”,当输入数值型数据时,数据之间用空格、回车或制表符隔开,间隔符个数不限。当进行数值型和字符型混合数据输
44、入时,数据之间不能用空格隔开,因为空格会被当作一个字符读入。31.以下程序运行后的输出结果是#includestdio.hstruct ordint x, y; dt2=1, 2, 3, 4;main()struct ord *P=dt;printf(“%d,“, +p-x); printf(“%d/n“, +p-y);(分数:2.00)A.1,2B.2,3 C.3,4D.4,1解析:解析 指针变量 p指向 dt0,p-x 即为 dt0.x,初值为 1,因为“-”的优先级大于“+”,所以先计算 p-x 的值加 1等于 2,并输出;再计算 p-y 的值加 1等于 3,并输出。因此,输出结果为2,
45、3。32.以下程序中的变量已正确定义,程序段的输出结果是for(i=0; i4; i+, i+)for(k=1; k3; k+); printf(“*“);(分数:2.00)A.*B.*C.*D.* 解析:解析 由于二重 for循环的循环体是空语句,因此,printf 函数不属于循环体,printf(“*“)语句只执行一次。33.软件按功能可以分为应用软件、系统软件和支撑软件(或工具软件)。下面属于应用软件的是(分数:2.00)A.编译软件B.操作系统C.教务管理系统 D.汇编程序解析:解析 软件按功能可以分为:应用软件、系统软件和支撑软件(或工具软件)。应用软件是为实现某一特定领域的应用而开
46、发的软件;系统软件是计算机管理自身资源,提高计算机使用效率并为计算机用户提供各种服务的软件;支撑软件是介于系统软件和应用软件之间,协助用户开发软件的工具性软件。编译程序、操作系统和汇编程序都属于系统软件;教务管理系统属于应用软件。34.数据库应用系统中的核心问题是(分数:2.00)A.数据库设计 B.数据库系统设计C.数据库维护D.数据库管理员培训解析:解析 数据库应用系统中的一个核心问题就是设计一个能满足用户需求、性能良好的数据库,这就是数据库设计。35.以下程序运行后的输出结果是#includestdio.hmain()char *a=“abcd“, “ef“, “gh“, “ijk“;
47、int i;for(i=0; i4; i+) printf(“%c“, *ai);(分数:2.00)A.aegi B.dfhkC.abcdD.abcdefghijk解析:解析 a 是一个长度为 4的指针数组,它的每一个元素分别指向一个字符串。该程序的功能是分别打印 4个字符串的首字母。36.以下程序运行时,输入的值在哪个范围才会有输出结果?#includestdio.hmain()int x;Scanf(“%d“, if(x=3); elseif(x!=10) printf(“%d/n“, x);(分数:2.00)A.不等于 10的整数B.大于 3且不等于 10的整数 C.大于 3或等于 10的整数D.小于 3的整数解析:解析 如果 x=3,则执行空语句;否则,再判断 x!=10。因此,只有当 x大于 3且不等于 10时,才有输出结果。37.以下程序运行后的输出结果是#includestdio.h