1、二级c语言考试真题2010年3月全国计算机等级考试二级笔试试卷C语言程序设计 一、选择题 (1) 下列叙述中正确的是 A) 对长度为n的有序链表进行查找,最坏情况下需要的比较次数为n B) 对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(n/2) C) 对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(10g2n) D) 对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(nlog2n) (2) 算法的时间复杂度是指 A) 算法的执行时间 B) 算法所处理的数据量 C) 算法程序中的语句或指令条数 D) 算法在执行过程中所需要的基本运算次数 (3) 软件按功
2、能可以分为:应用软件、系统软件和支撑软件(或工具软件)。下面属于系统软件的是 A) 编辑软件 B) 操作系统 C) 教务管理系统 D) 浏览器 (4) 软件(程序)调试的任务是 A) 诊断和改正程序中的错误 B) 尽可能多地发现程序中的错误 C) 发现并改正程序中的所有错误 D) 确定程序中错误的性质 (5) 数据流程图(DFD图)是 A) 软件概要设计的工具 B) 软件详细设计的工具 C) 结构化方法的需求分析工具 D) 面向对象方法的需求分析工具 (6) 软件生命周期可分为定义阶段,开发阶段和维护阶段。详细设计属于 A) 定义阶段 B) 开发阶段 C) 维护阶段 D) 上述三个阶段 (7)
3、 数据库管理系统中负责数据模式定义的语言是 A) 数据定义语言 B) 数据管理语言 C) 数据操纵语言 D) 数据控制语言 (8) 在学生管理的关系数据库中,存取一个学生信息的数据单位是 A) 文件 B) 数据库 C) 字段 D) 记录 (9) 数据库设计中,用E-R图来描述信息结构但不涉及信息在计算机中的表示,它属于数据库设计的 A) 需求分析阶段 B) 逻辑设计阶段 C) 概念设计阶段 D) 物理设计阶段 (10) 有两个关系R和T如下: 则由关系R得到关系T的操作是 A) 选择 B) 投影 C) 交 D) 并 (11) 以下叙述正确的是 A) C语言程序是由过程和函数组成的 B) C语言
4、函数可以嵌套调用,例如:fun(fun(x) C) C语言函数不可以单独编译 D) C语言中除了main函数,其他函数不可作为单独文件形式存在 (12) 以下关于C语言的叙述中正确的是 A) C语言中的注释不可以夹在变量名或关键字的中间 B) C语言中的变量可以在使用之前的任何位置进行定义 C) 在C语言算术表达式的书写中,运算符两侧的运算数类型必须一致 D) C语言的数值常量中夹带空格不影响常量值的正确表示 (13) 以下C语言用户标识符中,不合法的是 A) _1 B) AaBc C) a_b D) a-b (14) 若有定义:double a=22;int i=0,k=18;,则不符合C语
5、言规定的赋值语句是 A) a=a+,i+; B) i=(a+k)=(i+k); C) i=a%11; D) i=!a; (15) 有以下程序 #include main() chara,b,C,d; scanf(%c%c,&a,&b); c=getchar(); d=getchar(); printf(%c%c%c%cn,a,b,c,d); 当执行程序时,按下列方式输入数据(从第1列开始,代表回车,注意:回车也是一个字符) 12CR 34 则输出结果是 A) 1234 B) 12 C) 12 D) 12 3 34 (16) 以下关于C语言数据类型使用的叙述中错误的是 A) 若要准确无误差的表示
6、自然数,应使用整数类型 B) 若要保存带有多位小数的数据,应使用双精度类型 C) 若要处理如“人员信息”等含有不同类型的相关数据,应自定义结构体类型 D) 若只处理“真”和“假”两种逻辑值,应使用逻辑类型 (17) 若a是数值类型,则逻辑表达式(a=1)|(a!=1)的值是 A) 1 B) 0 C) 2 D) 不知道a的值,不能确定 (18) 以下选项中与if(a=1)a=b;else a+;语句功能不同的switch语句是 A) switch(a) case 1:a=b;break; default:a+; B) switch(a=1) case 0:a=b;break; case 1:a+
7、; C) switch(a) case 1:a=b;break; default:a+; D) switch(a=1) case 1:a=b;break; case 0:a+; (19) 有如下嵌套的if语句 if(ab) if(ac) k=a; else k=c; else if(bc) k=b; else k=c; 以下选项中与上述订语句等价的语句是 A) k=(ab)? a:b;k=(bc)?b:c; B) k=(ab)?(bc)?a:b):(bc)?b:c); C) k=(ab)?(ac)?a:c):(bc)?b:c); D) k=(ab)?a:b;k=(ac)?a:c; (20) 有
8、以下程序 #include main() int i,j,m=1; fori=i;i3;i+) for(j=3;j0;j-) if(i*j3)break; m*=i*j; printf(m=%dn,m); 程序运行后的输出结果是 A) m=6 B) m=2 C) m=4 D) m=5 (21) 有以下程序 #include main() int a=1,b=2; for( ;a8;a+) b+=a; a+=2; printf(%d,%dn,a,b); 程序运行后的输出结果是 A) 9,18 B) 8,11 C) 7,11 D) 10,14 (22) 有以下程序,其中k的初值为八进制数 #inc
9、lude main() intk=011; printf(%dn,k+); 程序运行后的输出结果是 A) 12 B) 11 C) 10 D) 9 (23) 下列语句组中,正确的是 A) char*s;s=”Olympic; B) chars7;s=Olympic; C) char*s;s=Olympic; D) chars7;s=Olympic; (24) 以下关于return语句的叙述中正确的是 A) 一个自定义函数中必须有一条return语句 B) 一个自定义函数中可以根据不同情况设置多条return语句 C) 定义成void类型的函数中可以有带返回值的return语句 D) 没有retu
10、rn语句的自定义函数在执行结束时不能返同到调用处 (25) 下列选项中,能正确定义数组的语句是 A) intnum0.2008; B) intnum; C) int N=2008; D) #defineN 2008 int numN; int numN; (26) 有以下程序 #include void fun(char*c,int d) *c=*c+1;d=d+1; printf(%c,%c,*c,d); main() charb=a,a=A; fun(&b,a);printf(%c,%cn,b,a); 程序运行后的输出结果是 A) b,B,b,A B) b,B,B,A C) a,B,B,a
11、 D) a,B,a,B (27) 若有定义int(*pt)3;,则下列说法正确的是 A) 定义了基类型为int的三个指针变量 B) 定义了基类型为int的具有三个元素的指针数组pt C) 定义了一个名为*pt、具有三个元素的整型数组 D) 定义了一个名为pt的指针变量,它可以指向每行有三个整数元素的二维数组 (28) 设有定义double a10,*s=a;,以下能够代表数组元索a3的是 A) (*s)3 B) *(s+3) C) *s3 D) *s+3 (29) 有以下程序 #include main() int a5=1,2,3,4,5,b5=0,2,1,3,0,i,s=0; for(i=
12、0;15;i+)s=s+abi; printf(%dn,s); 程序运行后的输出结果是 A) 6 B) 10 C) 11 D) 15 (30) 有以下程序 #include main() int b33=0,1,2,0,1,2,0,1,2,i,j,t=1; for(i=0;i3;i+) for(j=1;j=1;j+)t+=bibji; printf(%dn,t); 程序运行后的输出结果是 A) 1 B) 3 C) 4 D) 9 (31) 若有以下定义和语句 char s110=abcd!,*s2=n123; printf(%d%dn,strlen(s1),strlen(s2); 则输出结果是
13、A) 5 5 B) 10 5 C) 10 7 D) 5 8 (32) 有以下程序 #include #define N 8 void fun(int*x,int i *x=*(x+1); main() int aN=1,2,3,4,5,6,7,8,i; fun(a,2); for(i=0;iN/2;i+) printf(%d,ai); printf(n); 程序运行后的输山结果是 A) 1 3 1 3 B) 2 2 3 4 C) 3 2 3 4 D) 1 2 3 4 (33) 有以下程序 #include int f(int t,int n); main() inta4=1,2,3,4,s;
14、s=f(a,4);printf(%dn,s); int f(int t,int n) if(n0)returntn-1+f(t,n-1); else return 0; 程序运行后的输出结果是 A) 4 B) 10 C) 14 D) 6 (34) 有以下程序 #include intfun() static int x=1; x*=2;return x; main() int i,s=1; for(i=1;=2;i+) s=fun(); printf(%dn,s); 程序运行后的输出结果是 A) 0 B) 1 C) 4 D) 8 (35) 有以下程序 #include #define SUB(
15、a) (a)-(a) main() inta=2,b=3,c=5,d; d=SUB(a+b)*c; printf(%dn,d); 程序运行后的输山结果是 A) 0 B) -12 C) -20 D) 10 (36) 设有定义: stmct complex int real,unreal;datal=1,8,data2; 则以下赋值语句中错误的是 A) data2=datal; B) data2=(2,6); C) data2.real=datalreal; D) data2.real=datal.unreal; (37) 有以下程序 #include #include strtict A int
16、 a;char b10;double c; void f(struct A t); main() struct A a=1001,ZhangDa,10980; f(a);pfintf(%d,%s,%61fn”,aa,ab,ac); void f(struct A t) ta=1002;strcpy(tb,ChangRong);tc=12020; 程序运行后的输出结果是 A) 1001,ZhangDa,10980 B) 1002,ChangRong,12020 C) 1001,ChangRong,1098.0 D) 1002,ZhangDa,1202.0 (38) 有以下定义和语句 struct
17、 workers int nnm;charname20;charc; struct int day;int month;int year;s; ; struct workers w,*pw; pw=&w; 能给w中year成员赋1980的语句是 A) *pwyear=1980; B) wyear=1980; C) pw-year=1980; D) wsyear=1980; (39) 有以下程序 #include main() int a=2,b=2,c=2; printf(%dn,a/b&c); 程序运行后的输出结果是 A) 0 B) 1 C) 2 D) 3 (40) 有以下程序 #inclu
18、de main() FILE *kfp;charstr10; fp=fopen(myfiledat,w); fputs(abc,fp);fclose(fP); fP=fopen(my6ledat,a+); fprintff(fp,qat,28); rewind(fp); fscanf(fP,%,str);puts(str); fclose(fp); 程序运行后的输出结果是 A) abc B) 28c C) abc28 D) 因类型不一致而出错 二、填空题 (1) 一个队列的初始状态为空。现将元素A,B,C,D,E,F,5,4,3,2,1依次入队,然后再依次退队,则元素退队的顺序为 1 。 (2
19、) 设某循环队列的容量为50,如果头指针front=45(指向队头元素的前一位置),尾指针 rear=10(指向队尾元素),则该循环队列中共有 2 个元素。 (3)设二叉树如下: 对该二叉树进行后序遍历的结果为 3 。 (4) 软件是 4 数据和文档的集合。 (5) 有一个学生选课的关系,其中学生的关系模式为:学生(学号,姓名,班级,年龄),课程的关系模式为:课程(课号,课程名,学时),其中两个关系模式的键分别是学号和课号,则关系模式选课可定义为:选课(学号, 5 ,成绩)。 (6) 设x为int型变量,请写出一个关系表达式 6 ,用以判断x同时为3和7的倍数时,关系表达式的值为真。 (7)
20、有以下程序 #include main() int a=1,b=2,c=3,d=0; if(a=1) if(b! =2) if(c=3) d=1; else d=2; elseif(c!=3) d=3; else d=4; else d=5; printf(%dn,d); 程序远行后的输出结果是 7 。 (8) 有以下程序 #include main() int m,n; scanf(%d%d,&m,&n); while(m! =n) while(mn)m=m-n; while(mn)n=n-m; printf(%dn,m); 程序运行后,当输入14 63时,输出结果是 8 。 (9) 有以下
21、程序 #include main() int i,j,a3=1,2,3,4,5,6,7,8,9; for(i=0;13;i+ for(j=i;j3;j+) printf(%d,aij); printf(n); 程序运行后的输出结果是 9 (10) 有以下程序 #include main() int a=1,2,3,4,5,6,*k3,i=0; while(i3) ki=&a2*i; printf(%d,*ki); i+; 程序运行后的输出结果是 10 。 (11) 有以下程序 #include main() inta33=1,2,3),4,5,6,7,8,9; int b3=0,i; for(
22、i=0;i3;i+bi=ai2+a2i; for(i=0;13;i+)printf(%d,bi); printf(n); 程序运行后的输出结果是 11 。 (12) 有以下程序 #include #include void fun(char*str) char temp;int n,i; n=strlen(str); temp=strn-1; for(i=n-1;i0;i-) stri=stri-1); str0=temp; main() chars50; scanf(%s,s);fun(s);printf(%sn,s); 程序运行后输入:abcdef,则输出结果是 12 (13) 以下程序的
23、功能是:将值为三位正整数的变量x中的数值按照个位、十位、百位的顺序 拆分并输出。请填空。 #include main() int x=256; printf(%d-%d-%dkn, 13 ,x/10%10,x/100); (14) 以下程序用以删除字符串中所有的空格,请填空。 #include main() char s100=our teacher teach c language!”;int i,j; for(i=j=0;si!=0;i+) if(si!=) sj=si;j+; sj= 14 ; printf(%sn,s); (15) 以下程序的功能是:借助指针变量找出数组元素中的最大值及
24、其元素的下标值。请填空。 #include main() int a10,*p,*s; for(p=a;P-a10;p+)scanf(%d,p); for(p=a,s=a;p-a10;p+)if(*p*s)s= 15 ; printf(index=%dn,s-a); 2010年3月笔试试卷 一、选择题 (1) A) 解析 对长度为n的有序链表进行查找,最坏情况是从最小值开始查找最大值(或从最大值开始查找最小值),这个过程需要比较的次数为n,故选项A正确。对分查找只能针对随机存取的有序表进行,而有序链表只能进行顺序存取,不能进行随机存取,在有序链表上不能进行对分查找,故 B、C、D选项都错误。
25、(2) D) 解析 算法的时间复杂度是指算法需要消耗的时间资源,是独立于机器的,选项D正确;相同的算法在不同的机器上运行时间可能不同,选项A错误;算法所处理的数据量与算法无关,选项B错误;程序的长短与程序执行时需要消耗的时间资源没有必然的关系,比如一个条件语句可以很长,但只需判断一次,而一个循环语句可能只有几行,但可以执行很多次,故选项C错误。 (3) B) 解析 编辑软件、教务管理软件属于应用软件,操作系统属于系统软件,浏览器属于支撑软件,故本题答案选B。 (4) A) 解析 软件调试的任务是诊断和改正程序中的错误,本题正确答案为A。其他三项描述不正确,选项B描述不全面,选项C描述太绝对,选
26、项D描述不符合定义。 (5) C) 解析 数据流图是结构化分析方法中使用的工具,它以图形的方式描绘数据在系统中流动和处理的过程。软件结构图是软件概要设计的工具,而详细设计是对概要设计的每个模块进行细化,UML是面向对象的需求分析的工具。 (6) B) 解析 软件定义阶段的基本任务是确定软件系统的工程需要,分为软件系统的可行性研究和项目需求分析。软件开发阶段包括概要设计、详细设计、实现、组装测试和确认测试5个阶段。维护阶段主要是软件的使用、系统维护和系统更新换代。 (7) A) 解析 数据定义语言用于定义数据库的所有特性和属性,如行布局、列定义、文件位置和存储策略等。 (8) D) 解析 在关系
27、数据表中,行称为元组,对应存储文件中的记录,列称为属性,对应存储文件中的字段,所以本题答案为D。 (9) C) 解析 E-R图即实体-联系图(Entity-Rela- tion Diagram),用来建立数据模型,在数据库系统概论中属于概念设计阶段。 (10) A) 解析 关系T中的两行和关系R中的最后两行一致,通过选择运算即可由R得到T。 (11) B) 解析 C语言中只有函数没有过程,故选项A错误;C语言可以嵌套调用,故选项B正确;C语言函数可以单独编译成dll文件,故选项C错误;C语言中除main函数以外,其他函数可作为单独文件形式存在,故选项D也错误。 (12) B) 解析 C语言中注释可以放在任何位置,选项 A错误;C语言中的变量只要在使用之前定义即可,位置可以是使用前的任何位置,故选项B正确;C语言中两侧数据类型可以不一致,系统可进行强制类型转换,选项C错误;C语言数值常量中不允许存在空格,选项D错误。 (13) D) 解析 标识符由字母、下划线、数字三个方面组成,开头必须是字母或下划线。 (14) C) 解析 C语言中取余运算符两侧的操作数只能是整型(若为char型,则会自动转换成整型)。 (15
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1