1、二级 C 语言笔试-243 及答案解析(总分:100.00,做题时间:90 分钟)一、选择题(总题数:40,分数:70.00)1.下列语句段中,正确的是( )。(分数:2.00)_2.当说明一个结构体变量时系统分配给它的内存是( )。(分数:2.00)A.各成员所需要内存量的总和B.结构中第一个成员所需的内存量C.成员中占内存最大者所需的容量D.结构中最后一个成员所需要的内存量3.设 x=011050,则 x=xfor(i=1 ;i=n;i+) f*=i;B.f=1;for(i=1;in;i+) f*=i;C.f=1;for(i=n;i1;i+)f*=i;D.f=1;for(i=n;i =2;
2、i-)f*=i;5.下列程序的输出结果是( )。#includestdio.hint b=2;int fune(int*(分数:2.00)A.输出的结果是( )。(分数:2.00)A.x=123.46B.123.4567C.x=123.4567D.123.468.设已包含头文件string.h,下列程序段的运行结果是( )。char s1=“ACDEF“;char s2=“ABC“;strcpy(s1,s2);printf(“%d“,strlen(s1);(分数:2.00)A.3B.4C.6D.59.设有定义下列:int a=1,b=2,c=3,d=4,m=2,n=2;则表达式(m=ab)ch
3、ar n=1,2,3,4,5,6,7;则下列叙述正确的是( )。(分数:2.00)A.数组 m 与数组 n 完全相同B.数组 m 与数组 n 长度相同C.数组 m 比数组 n 长 1D.数组 m 与数组 n 中都存放字符串11.算法的空间复杂度是指( )。(分数:1.00)A.算法程序的长度B.算法程序中的指令条数C.算法程序所占的存储空间D.算法执行过程中所需要的存储空间12.执行下列程序段后,变量 a,b,c 的值分别是( )。int x=5,y=4;int a,b,c;a=(-x=y+)?x:+y;b=+x;c=y;(分数:1.00)A.a=5, b=5, c=5B.a=4, b=5,
4、c=5C.a=5, b=6, c=5D.a=1, b=5, c=613.下列程序的输出结果是( )。void f(int *x, int *y)int t;t=*x,*x=*y;*y=t;main( )int a8= 1,2,3,4,5,6,7,8,i,*p,*q;p=a;q=while(pq)f(p,q); p+; q-;for (i=0;i8;i+) printf(“%d,“,ai);(分数:1.00)A.8,2,3,4,5,6,7,1B.5,6,7,8,1,2,3,4C.1,2,3,4,5,6,7,8D.8,7,6,5,4,3,2,114.下列变量声明合法的是( )。(分数:1.00)A
5、.short a=1.4e-1;B.double b=1+3e2.8;C.long do=0xfdaL;D.float2_aaa=1e-3;15.已知函数 fread 的调用形式为 fread(buffet,size,count,fp);,其中 buffer 代表的是( )。(分数:1.00)A.存放读入数据项的存储区B.一个指向所读文件的文件指针C.一个指针,是指向输入数据存放在内存中的起始地址D.一个整型变量,代表要读入的数据项总数16.下列程序的输出结果是( )。main()int a=1,b=2;printf(“%d,%d/n“,-a,+b);(分数:1.00)A.1,2B.1,3C.
6、0,2D.0,317.在 C 语言中,函数调用时( )。(分数:1.00)A.实参和形参各占独立的存储单元B.实参和形参共用存储单元C.由系统自动确定实参和形参是否共用存储单元D.由用户指定实参和形参是否共用存储单元18.结构化程序设计主要强调的是( )。(分数:1.00)A.程序的规模B.程序的效率C.程序设计语言的先进性D.程序的易读性19.已有定义:char a=“xyz“, b=x, y, z;,下列叙述中正确的是( )。(分数:1.00)A.数组 a 和 b 的长度相同B.a 数组长度小于 b 数组长度C.a 数组长度大于 b 数组长度D.上述说法都不对20.下列程序的输出结果是(
7、)。#includestdio.hmain()char a= a,b,c,d,e,f,/0;int i,j;i=sizeof((分数:1.00)A.;for(i=1;i=10;i+)if(i*i=20)printf(“%d/n“,i*i);(分数:2.00)A.49B.36C.25D.6423.下列所述中,是软件调试技术的是( )。(分数:2.00)A.错误推断B.集成测试C.回溯法D.边界值分析24.数据库 DB、数据库系统 DBS、数据库管理系统 DBMS 之间的关系是( )。(分数:2.00)A.DB 包括 DBS 和 DBMSB.DBMS 包括 DB 和 DBSC.DBS 包括 DB
8、和 DBMSD.没有任何关系25.有下列二叉树,对此二叉树前序遍历的结果为( )。(分数:2.00)A.B.C.D.26.下列程序的运行结果是( )。#includestdio.h#define ADD(x) x+xmain()int m=1,n=2,k=3;int s=ADD(m+n)*k;printf(“s=%d“,s);(分数:2.00)A.sum=18B.sum=10C.sum=9D.sum=2527.下列叙述中正确的是( )。(分数:2.00)A.C 程序由函数组成B.C 程序由主函数构成C.C 程序由函数和过程构成D.在 C 程序中无论是整数还是实数,都可以正确无误的表示出来28.
9、下列程序执行的输出结果是( )。#includestdio.hmain()char a24;strcpy(a,“are“);strcpy(a1,“you“);a03=printf(“%s/n“,(分数:2.00)A.;A) are,下列赋值语句中与 n2=n1;语句等价的是( )。(分数:2.00)A.*p=*q;B.p=q;C.*p=D.p=*q;31.在函数 scanf 的格式控制中,格式说明的类型与输入项的类型应该对应匹配。如果类型不匹配,系统将( )。(分数:2.00)A.不予接收B.并不给出出错信息,但不能得到正确的数据C.能接收到正确输入D.给出出错信息,不予接收输入32.若有定义
10、 float a=25, b,*p=,则下列对赋值语句*p=a; 和 p=c=getchar();if(c=aelse if(c=gelse printf(“input error!/n“);putchar(c);(分数:2.00)A.fB.tC.eD.d34.下列叙述中正确的是( )。(分数:2.00)A.线性链表的各元素在存储空间中的位置必须是连续的B.线性链表的头元素一定存储在其他元素的前面C.线性链表中的各元素在存储空间中的位置不一定是连续的,但表头元素一定存储在其他元素的前面D.线性链表中的各元素在存储空间中的位置不一定是连续的,且各元素的存储顺序也是任意的35.若执行下列的程序时,
11、从键盘上输入 1 和 2,则输出结果是( )。#includestdio.hmain()int a,b,s;scanf(“%d%d“,s=a;if(ab) s=b;s=s*s;printf(“%d/n“,s);(分数:2.00)A.1B.4C.2D.936.结构化分析方法是面向( )的自顶向下逐步求精进行需求分析的方法。(分数:2.00)A.对象B.数据结构C.数据流D.目标37.有下列程序:main()int t, a=1, b=5, c=-2;while(abc)t=a; a=b; b=t; c+;printf(“%d, %d, %d“, a, b, c);(分数:2.00)A.1, 5,
12、 0B.1, 5, -2C.5, 1, -1D.5, 1, -238.一个源文件中的外部变量的作用域为( )。(分数:2.00)A.本文件的全部范围B.本程序的全部范围C.本函数的全部范围D.从定义该变量的位置开始到本文件结束39.若有定义 int b8, *p=b; 则 p+6 表示( )。(分数:2.00)A.数组元素 b6的值B.数组元素 b6的地址C.数组元素 b7的地址D.数组元素 b0的值加上 640.按照“先进先出”组织数据的数据结构是( )。(分数:2.00)A.队列B.栈C.双向链表D.二叉树二、填空题(总题数:15,分数:30.00)41.数据的独立性分为逻辑独立性与物理独
13、立性。当数据的存储结构改变时,其逻辑结构可以不变,因此,基于逻辑结构的应用程序不必修改,这称为 1。(分数:2.00)填空项 1:_42.在关系模型中,二维表的行称为 1。(分数:2.00)填空项 1:_43.数据库系统其内部分为三级模式,即概念模式、内模式和外模式。其中, 1 是用户的数据视图,也就是用户所见到的数据模式。(分数:2.00)填空项 1:_44.排序是计算机程序设计中的一种重要操作,常见的排序方法有插入排序、 1 和选择排序。(分数:2.00)填空项 1:_45.栈的 3 种基本运算是:入栈、退栈和 1。(分数:2.00)填空项 1:_46.若 a 的值为 1,则表达式!a+a
14、 的值是 1。(分数:2.00)填空项 1:_47.若 a 是 int 型变量,且 a 的初值为 4,则计算 a+=a-=a*a 表达式后 a 的值为 1。(分数:2.00)填空项 1:_48.下列程序的输出结果是_。#includestdio.hmain()int a=2,b=- 1,c=2;if(ab)if(b0) c=0;else c+;printf(“%d/n“,c);(分数:2.00)填空项 1:_49.下列程序的循环次数是_。x=2;dox=x*x;while(!x);(分数:2.00)填空项 1:_50.下列程序段的运行结果是_。int x=0,y=0;while(x15) y+
15、,x+=+y;printf(“%d,%d“,y,x);(分数:2.00)填空项 1:_51.下列程序的运行结果是_。main()int s=0,i=1;while(s=10)s=s+i*i;i+;printf(“%d“,-i);(分数:2.00)填空项 1:_52.下列程序的输出结果是_。long fun5(int n)long s;if(n=1)(n=2)s=2;elses=n+fun5(n-1);return(s);main()long x;x=fun5(4);printff“%1d/n“,x);(分数:2.00)填空项 1:_53.下列程序的输出结果是_。main()int a=2,b=
16、4,e=6;int*p1=*(p=printf(“%d/n“,c);(分数:2.00)填空项 1:_54.下列程序运行后的输出结果是_。#includestdio.hmain()char s20;scanf(“%s“,s);printf(“%s“,s);运行程序,输入 HOW ARE YOU。(分数:2.00)填空项 1:_55.下列程序的运行结果是_。#define POW(r)(r)*(r)main()int x=3,y=2,t;t=POW(x+y);printf(“%d/n“,t);(分数:2.00)填空项 1:_二级 C 语言笔试-243 答案解析(总分:100.00,做题时间:90
17、分钟)一、选择题(总题数:40,分数:70.00)1.下列语句段中,正确的是( )。(分数:2.00)_解析:解析 本题主要考查的知识点是结构类型的概念和定义,结构定义的一般形式是:struct 结构类型名称 数据类型 成员名 1;数据类型 成员名 2;数据类型 成员名 n;struct 为关键字,是结构的标识符:2.当说明一个结构体变量时系统分配给它的内存是( )。(分数:2.00)A.各成员所需要内存量的总和 B.结构中第一个成员所需的内存量C.成员中占内存最大者所需的容量D.结构中最后一个成员所需要的内存量解析:解析 本题主要考查结构体的内存使用:对结构体而言,结构中不同的成员分别使用不
18、同的内存空间,一个结构所占内存空间的大小是结构中每个成员所占内存空间大小的总和,结构中每个成员相互独立。3.设 x=011050,则 x=xfor(i=1 ;i=n;i+) f*=i;B.f=1;for(i=1;in;i+) f*=i;C.f=1;for(i=n;i1;i+)f*=i;D.f=1;for(i=n;i =2;i-)f*=i; 解析:解析 要正确计算函数 f=n!,由 n!的数学定义可知 n!-n*(n-1)*(n-2)*1。在选项 A)中,由于 f 的初值为 0,在 for 循环语句中 f 依次乘以 1,2,3,n。最后计算 f=n!=0,所以选项 A)不正确。在选项 B)中,f
19、 的初值为 1,在 for 循环语句中,f 依次乘以 1,2,3,(n-1)。最后计算得到f=(n-1)!,所以选项 B)不正确。在选项 C)中,f 的初值为 1,在 for 循环语句中,f 依次乘以 n,n+1, n+2,所以选项 C)不正确在选项 D)中,f 的初值为 1,在 for 循环语句中,f 依次乘以 n,n-1,n-2,2。最后计算 f=n!,所以选项 D)正确。5.下列程序的输出结果是( )。#includestdio.hint b=2;int fune(int*(分数:2.00)A.输出的结果是( )。(分数:2.00)A.x=123.46 B.123.4567C.x=123
20、.4567D.123.46解析:解析 本题考查 printf 函数的格式。“%5.2f”格式符中的“f”表示以带小数点的形式输出单精度或者双精度数;“5”表示指定数据输出宽度为 5;“.2”表示指定输出数据小数位占 2 位数,并对截去的第一位小数做四舍五入处理。8.设已包含头文件string.h,下列程序段的运行结果是( )。char s1=“ACDEF“;char s2=“ABC“;strcpy(s1,s2);printf(“%d“,strlen(s1);(分数:2.00)A.3 B.4C.6D.5解析:解析 头文件string.h是字符串处理函数对应的头文件,要想调用 C 语言的库函数时,
21、都要在程序中嵌入该函数对应的头文件,否则无法使用库函数。strcpy(s1,s2)把,2 中的字符串复制到 s1 中,所以结果就为 s2 的长度。9.设有定义下列:int a=1,b=2,c=3,d=4,m=2,n=2;则表达式(m=ab)char n=1,2,3,4,5,6,7;则下列叙述正确的是( )。(分数:2.00)A.数组 m 与数组 n 完全相同B.数组 m 与数组 n 长度相同C.数组 m 比数组 n 长 1 D.数组 m 与数组 n 中都存放字符串解析:解析 本题考查字符数组和字符串赋值给数组的一些区别。语句“char m=“1234567“;”定义了一个字符型数组并进行了初始
22、化,C 语言规定,在字符串的末尾自动加上串结束标记/0,因此数组 m 的长度是 8:而数组 n 是按照字符方式对数组进行初始化,系统不会自动加上串结束标记/0,因此数组 n 的长度是 7。11.算法的空间复杂度是指( )。(分数:1.00)A.算法程序的长度B.算法程序中的指令条数C.算法程序所占的存储空间D.算法执行过程中所需要的存储空间 解析:解析 一个算法的空间复杂度,一般是指执行这个算法所需的存储空间。一个算法所占用的存储空间包括算法程序所占用的空间、输入的初始数据所占用的存储空间及算法执行过程中所需要的额外空间。12.执行下列程序段后,变量 a,b,c 的值分别是( )。int x=
23、5,y=4;int a,b,c;a=(-x=y+)?x:+y;b=+x;c=y;(分数:1.00)A.a=5, b=5, c=5B.a=4, b=5, c=5 C.a=5, b=6, c=5D.a=1, b=5, c=6解析:解析 本题考查自加(+)、自减(-)运算符的使用。“+i,-i”,在使用 i 之前,先使 i 的值加1 或者减 1,再使用此时的表达式的值参与运算:“i+,i-”,先使用此时的 i 的值参与运算,在使用i 之后,再使 i 的值加 1 或者减 1。对于第 1 个表达式-x=4,y+=4。两者相等,-x=y+为真,所以 a=x=4,执行完此语句后 y 的值是 5。第 2 个表
24、达式 b=+x,x 的值先加 1,然后赋给 b,即 b=x+1=5;第一个表达式 c=y=5。13.下列程序的输出结果是( )。void f(int *x, int *y)int t;t=*x,*x=*y;*y=t;main( )int a8= 1,2,3,4,5,6,7,8,i,*p,*q;p=a;q=while(pq)f(p,q); p+; q-;for (i=0;i8;i+) printf(“%d,“,ai);(分数:1.00)A.8,2,3,4,5,6,7,1B.5,6,7,8,1,2,3,4C.1,2,3,4,5,6,7,8D.8,7,6,5,4,3,2,1 解析:解析 函数 f()
25、的功能是对两个数据互换。在主函数中指针变量 p 和 q 分别指向数组 a8的首和尾,在 while 循环中实现从首尾开始数组元素的互换操作。14.下列变量声明合法的是( )。(分数:1.00)A.short a=1.4e-1; B.double b=1+3e2.8;C.long do=0xfdaL;D.float2_aaa=1e-3;解析:解析 解答本题需了解 3 个知识点:标识符是由字母、数字或下画线组成,并且它的第一个字符必须是字母或者下画线;do 是 C 语言中的一个关键字,不能再用做变量名和函数名;C 语言规定指数形式的实型常量 e 或 E 后面的指数必须是整数。15.已知函数 fre
26、ad 的调用形式为 fread(buffet,size,count,fp);,其中 buffer 代表的是( )。(分数:1.00)A.存放读入数据项的存储区B.一个指向所读文件的文件指针C.一个指针,是指向输入数据存放在内存中的起始地址 D.一个整型变量,代表要读入的数据项总数解析:解析 数据块读取函数调用形式:fread(buffer,size,count,fp)。fread 函数参数说明:“buffer”是一个指针,对 fread 来说,它是读入数据的存放地址。对 fwrite 来说,是要输出数据的地址。“size”是要读写的字节数;“count”是要进行读写多少个 size 字节的数据
27、项;“fp”是指文件型指针。16.下列程序的输出结果是( )。main()int a=1,b=2;printf(“%d,%d/n“,-a,+b);(分数:1.00)A.1,2B.1,3C.0,2D.0,3 解析:解析 本题主要考查自加(+)、自减(-)运算符的使用。“+i,-i”在使用 i 之前,先使 i 的值加 1 或者减 1,然后再使用 i 此时的值参与运算;“i+,i-”是在使用 i 参与表达式运算之后,再使 i的值加 1 或者减 1本题中-a 和+b 是先执行 a 减 1 和 b 加 1 操作,再输出表达式的值。17.在 C 语言中,函数调用时( )。(分数:1.00)A.实参和形参各
28、占独立的存储单元 B.实参和形参共用存储单元C.由系统自动确定实参和形参是否共用存储单元D.由用户指定实参和形参是否共用存储单元解析:解析 本题考查函数调用时的参数传递。函数的形参是函数定义时由用户定义的形式上的变量,实参是函数调用时,主调函数;被调函数提供的原始数据。在函数调用时,实参和其所对应的形参分别占用不同的存储单元,彼此之间不影响。18.结构化程序设计主要强调的是( )。(分数:1.00)A.程序的规模B.程序的效率C.程序设计语言的先进性D.程序的易读性 解析:解析 程序不光是编写完就结束了,为了测试和维护程序,往往还有其他人阅读和跟踪程序,因此,程序设计的风格应该强调简单和清晰,
29、即程序的易读性,“清晰第一,效率第二”。19.已有定义:char a=“xyz“, b=x, y, z;,下列叙述中正确的是( )。(分数:1.00)A.数组 a 和 b 的长度相同 B.a 数组长度小于 b 数组长度C.a 数组长度大于 b 数组长度D.上述说法都不对解析:解析 字符数组现)中用字符串常量“xyz”进行初始化,字符数组 a的长度为宁符的个数,所以其值为 3,并不包括字符串结束标记/0;字符串数组 b用 3 个字符x、y、z来初始化,所以其字符串的长度等于 3。20.下列程序的输出结果是( )。#includestdio.hmain()char a= a,b,c,d,e,f,/
30、0;int i,j;i=sizeof((分数:1.00)A.;for(i=1;i=10;i+)if(i*i=20)printf(“%d/n“,i*i);(分数:2.00)A.49B.36C.25 D.64解析:解析 本题考查 if 语句当执行到第一个满足(i*i=20)int s=ADD(m+n)*k;printf(“s=%d“,s);(分数:2.00)A.sum=18B.sum=10 C.sum=9D.sum=25解析:解析 本题考查带参数的宏的定义及相关运算:s=m+n+m+n*k=1+2+1+2*3=10。27.下列叙述中正确的是( )。(分数:2.00)A.C 程序由函数组成 B.C
31、程序由主函数构成C.C 程序由函数和过程构成D.在 C 程序中无论是整数还是实数,都可以正确无误的表示出来解析:解析 本题涉及 C 语言最基本的两个知识点:C 程序是由函数构成的,有且仅有一个主函数,也可以有其他的函数;整数在允许的范围内可以准确无误的表示出来,但计算机的存储能力有限,不能表示无限精度的实数。28.下列程序执行的输出结果是( )。#includestdio.hmain()char a24;strcpy(a,“are“);strcpy(a1,“you“);a03=printf(“%s/n“,(分数:2.00)A.;A) are,下列赋值语句中与 n2=n1;语句等价的是( )。(
32、分数:2.00)A.*p=*q; B.p=q;C.*p=D.p=*q;解析:解析 在定义指针变量 p 和 q 时,分别把变量 n2 和 n1 的地址赋给了指针变量 p 和 q,所以*p 和*q 中内容就分别是变量 n2 和 n1 的值,所以语句*p=*q 与语句 n2=n1 等价。因此选项 A)正确。31.在函数 scanf 的格式控制中,格式说明的类型与输入项的类型应该对应匹配。如果类型不匹配,系统将( )。(分数:2.00)A.不予接收B.并不给出出错信息,但不能得到正确的数据 C.能接收到正确输入D.给出出错信息,不予接收输入解析:解析 在 scanf 函数的格式控制中,格式说明的类型与
33、输入项的类型必须一一对应匹配,如不匹配将导致数据输入出现错误,但是系统并不报错。32.若有定义 float a=25, b,*p=,则下列对赋值语句*p=a; 和 p=c=getchar();if(c=aelse if(c=gelse printf(“input error!/n“);putchar(c);(分数:2.00)A.fB.tC.e D.d解析:解析 首先,getchar 函数通过键盘读入字符a,即 c=a(其实 c 得到的是字符 a 的 ASCII 码值),然后判断 if 语句的控制条件,发现a=ascanf(“%d%d“,s=a;if(ab) s=b;s=s*s;printf(“
34、%d/n“,s);(分数:2.00)A.1B.4 C.2D.9解析:解析 本题考查 if 语句。scanf 函数通过键盘读入 a、b 的值,a=1,b=2。第一个 if 语句,先判断条件,发现 ab 条件成立,则 s=b=2, s=s*s=4。36.结构化分析方法是面向( )的自顶向下逐步求精进行需求分析的方法。(分数:2.00)A.对象B.数据结构C.数据流 D.目标解析:解析 结构化分析方法是面向数据流进行需求分析的方法,采用自顶向下、逐层分解,建立系统的处理流程,以数据流图和数据字典为主要工具,建立系统的逻辑模型。37.有下列程序:main()int t, a=1, b=5, c=-2;
35、while(abc)t=a; a=b; b=t; c+;printf(“%d, %d, %d“, a, b, c);(分数:2.00)A.1, 5, 0 B.1, 5, -2C.5, 1, -1D.5, 1, -2解析:解析 本题考查 while 循环。先判断 while 循环的控制表达式是否成立,发现 abc 不成立,所以不执行循环。直接输出 a、b、c 的值。38.一个源文件中的外部变量的作用域为( )。(分数:2.00)A.本文件的全部范围B.本程序的全部范围C.本函数的全部范围D.从定义该变量的位置开始到本文件结束 解析:解析 一个源文件中的外部变量的作用域是从定义该变量的位置开始到本
36、文件结束。39.若有定义 int b8, *p=b; 则 p+6 表示( )。(分数:2.00)A.数组元素 b6的值B.数组元素 b6的地址 C.数组元素 b7的地址D.数组元素 b0的值加上 6解析:解析 指针中存放的是变量的地址,指针也可以进行增减运算,这时指针移动的最小单位是一个存储单元,而不是一个字节。所以题中将 p+6 指的是将指针向后移动了 6 个存储单元,指向 b6,存放的是 b6的地址。40.按照“先进先出”组织数据的数据结构是( )。(分数:2.00)A.队列 B.栈C.双向链表D.二叉树解析:解析 队列是一种特殊的线性表,只允许在表的一端插入元素,在表的另一端删除元素,插
37、入元素的一端叫“队尾”,删除元素的一端叫“队头”,先插入的元素先被删除,是按“先进先出”的原则组织数据的。二、填空题(总题数:15,分数:30.00)41.数据的独立性分为逻辑独立性与物理独立性。当数据的存储结构改变时,其逻辑结构可以不变,因此,基于逻辑结构的应用程序不必修改,这称为 1。(分数:2.00)填空项 1:_ (正确答案:物理独立性)解析:解析 数据的独立性是指数据和应用程序相互独立,分为物理独立性和逻辑独立性其中物理独立性是指数据的物理结构(包括存储结构、存取方式)改变时,不需要修改应用程序。而逻辑独立性是指当逻辑结构改变时,不需要修改应用程序。42.在关系模型中,二维表的行称为
38、 1。(分数:2.00)填空项 1:_ (正确答案:元组)解析:解析 在关系型数据库中,用二维表来表示关系,二维的表名即关系名,二维表的行称为关系的元组,二维表的列,称为关系的属性。43.数据库系统其内部分为三级模式,即概念模式、内模式和外模式。其中, 1 是用户的数据视图,也就是用户所见到的数据模式。(分数:2.00)填空项 1:_ (正确答案:外模式)解析:解析 数据库系统的三级模式分别是内模式、概念模式和外模式。其中,物理模式给出了数据库的物理存储结构和存取方法;概念模式是数据库系统中全局数据逻辑结构的描述:外模式是用户的数据视图,也就是用户所见到的数据模式。44.排序是计算机程序设计中
39、的一种重要操作,常见的排序方法有插入排序、 1 和选择排序。(分数:2.00)填空项 1:_ (正确答案:交换样序)解析:解析 所谓排序是指将一个无序序列整理成按值非递减顺序排列成的有序序列,常用的排序方法有;交换排序、插入排序和选择排序。其中交换排序包括冒泡排序和快速排序,插入排序包括简单插入排序和希尔排序,选择排序包括直接选择排序和堆排序。45.栈的 3 种基本运算是:入栈、退栈和 1。(分数:2.00)填空项 1:_ (正确答案:读栈顶元素)解析:解析 栈的基本运算有 3 种:入栈、退栈和读取栈顶元素。其中,入栈是指在栈顶插入一个新的元素:退栈是指取出栈顶元素并赋值给一个变量;读栈顶元素
40、是将栈顶元素赋值给一个指定的变量,不删除栈顶元素。46.若 a 的值为 1,则表达式!a+a 的值是 1。(分数:2.00)填空项 1:_ (正确答案:1)解析:解析 逻辑运算中,非 1 即 0,非 0 即 1,!a=0,+a 为逻辑 1,所以 0 和 1 相或结果为 1。47.若 a 是 int 型变量,且 a 的初值为 4,则计算 a+=a-=a*a 表达式后 a 的值为 1。(分数:2.00)填空项 1:_ (正确答案:-24)解析:解析 本题考查赋值运算符 a+=b 等价于 a=a+b;a-=a*a 等价于 a=a-a*a=4-4*4=-12;a+=a,即a=a+a=-24。48.下列
41、程序的输出结果是_。#includestdio.hmain()int a=2,b=- 1,c=2;if(ab)if(b0) c=0;else c+;printf(“%d/n“,c);(分数:2.00)填空项 1:_ (正确答案:2)解析:解析 分析程序,a=2,b=-1,c=2 时,if 语句的表达式 ab 不成立,不再往下判断,直接退出if 语句,执行后面的输出语句,程序结束。在这个程序中 a、b、c 的值没做任何改变。49.下列程序的循环次数是_。x=2;dox=x*x;while(!x);(分数:2.00)填空项 1:_ (正确答案:1)解析:解析 dowhile 语句的功能是:首先执行
42、循环体语句,然后检测循环控制条件表达式的值,若为真,则重复执行循环体语句,否则退出循环;dowhile 语句的特点是先执行后判断,因此循环体至少执行 1 次。本程序中 x=2 不符合循环条件,所以只循环 1 次。50.下列程序段的运行结果是_。int x=0,y=0;while(x15) y+,x+=+y;printf(“%d,%d“,y,x);(分数:2.00)填空项 1:_ (正确答案:8,20)解析:解析 本题考查 while 循环和+运算符的运用。x=0 符合条件 x15,则执行 y+,x+=+y 后,y=1,x=0+2=2 后 y=2,符合条件继续循环,y=3,x=x+4=6 后 y
43、=4,再循环 y=5,x=x+6=6+6=12 后,y=6,继续循环 y=7,x=x+8=12+8-20,此时 y=8。51.下列程序的运行结果是_。main()int s=0,i=1;while(s=10)s=s+i*i;i+;printf(“%d“,-i);(分数:2.00)填空项 1:_ (正确答案:3)解析:解析 分析程序运行过程,第 1 次循环:s=s+i*i=0+1*1=1,i=2;第 2 次循环:s=s+i*i=1+2*2=5,i=3;第 3 次循环:s=s+i*i=5+3*3=14, i=4;循环条件不成立输出 i,-i 使 i 的值减 1,输出结果为 3。52.下列程序的输出
44、结果是_。long fun5(int n)long s;if(n=1)(n=2)s=2;elses=n+fun5(n-1);return(s);main()long x;x=fun5(4);printff“%1d/n“,x);(分数:2.00)填空项 1:_ (正确答案:9)解析:解析 考查 if else 语句,n=4 不满足条件,所以 fun5(4)=4+fun5(3),n=3 也不满足条件,fun5(3)=3+funS(2),n=2 满足条件 fun5(2)=2,故 x=4+3+2=9。53.下列程序的输出结果是_。main()int a=2,b=4,e=6;int*p1=*(p=pri
45、ntf(“%d/n“,c);(分数:2.00)填空项 1:_ (正确答案:8)解析:解析 本程序定义了 3 个指针变量 p1、p2、p,并且将 a、b 的地址分别赋给 p1、p2,则*p1=a=2,*p2=b=4,所以表达式*p1*(*p2)的值是 8。在赋值语句的左边是*(p=scanf(“%s“,s);printf(“%s“,s);运行程序,输入 HOW ARE YOU。(分数:2.00)填空项 1:_ (正确答案:HOW)解析:解析 在 scanf()函数中,使用空格作为分隔符,如果输入含有空格的字符中,则不能使用scanf()数,所以本题中输入空格就返回了/0/, s 数组也就确定了,后面的输入就不再读入数组 s 中。55.下列程序的运行结果是_。#define POW(r)(r)*(r)main()int x=3,y=2,t;t=POW(x+y);printf(“%d/n“,t);(分数:2.00)填空项 1:_ (正确答案:29)解析:解析 本题考查带参数的宏的定义及相关运算。运算过程为:t=POW(x+y)=(2+3)*(2+3)=25。