《2010-2011年二级C语言笔试真题及答案(共48页).doc》由会员分享,可在线阅读,更多相关《2010-2011年二级C语言笔试真题及答案(共48页).doc(48页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、精选优质文档-倾情为你奉上一、选择题 (1)下列叙述中正确的是A)对长度为n的有序链表进行查找,最坏清况下需要的比较次数为nB)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(n/2)C)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(log2n)D)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(nlog2n)(2)算法的时问复杂度是指A)算法的执行时间B)算法所处理的数据量C)算法程序中的语司或指令条数D)算法在执行过程中所需要的基本运算次数(3)软件按功能可以分为:应用软件、系统软件和支撑软件(或工具软件)。下面属于系统软件的是A)编辑软件B)操
2、作系统C)教务管理系统D)浏览器(4)软件(程序)调试的任务是A)诊断和改正程序中的错误B)尽可能多地发现程序中的错误C)发现并改正程序中的所有错误D)确定程序中错误的性质(5)数据流程图(DFD图)是A)软件概要设计的工具B)软件详细设计的工具C)结构化方法的需求分析工具D)面向对象方法的需求分析工具(6)软件生命周期可分为定义阶段,开发阶段和维护阶段。详细设计属于A)定义阶段B)开发阶段C)维护阶段D)上述三个阶段(7)数据库管理系统中负责数据模式定义的语言是A)数据定义语言B)数据管理语言C)数据操纵语言D)数据控制语言(8)在管理的关系数据库中,存取一个学生信息的数据单位是A)文件B)
3、数据库C)字段D)记录(9)数据库设计中,用E-R图来描述信息结构但不涉及信息在中的表示,它属于数据库设计的A)需求分析阶段B)逻辑设计一阶段C)概念设计阶段D)物理设计阶段(10)有两个关系R和T如下:则由关系K得到关系T的操作是A)选择B)投影C)交D)并(11)以下叙述正确的是A)程序是由过程和函数组成的B)C语言函数可以嵌套调用,例如:fun(fun(x)C)C语言函数不可以单独编译D)C语言中除了main函数,其他函数不可作为单独文件形式存在(12)以下关于C语言的叙述中正确的是A)C语言中的注释不可以夹在变量名或关键字的中间B)C语言中的变量可以在使用之前的任何位置进行定义C)在C
4、语言算术表达式的书写中,运算符两侧的运算数类型必须一致D)C语言的数值常量中夹带空格不影响常量值的正确表示(13)以下C语言用户标识符中,不合法的是A)_1B)AaBcC)a_bD)ab(14)若有定义:double a=22;int i=0,k=18;,则不符合C语言规定的赋值语句是A)a=a+,i+;B)i=(a+k)=(i+k);C)i=a%11;D)i=!a;(15)有以下程序#includemain() char a,b,c,d;scanf(“%c%c”,&a,&b);c=getchar(); d=getchar();printf(“%c%c%c%cn”,a,b,c,d);当执行程序
5、时,按下列方式输入数据(从第1列开始,代表回车,注意:回车也是一个字符)1234则输出结果是A)1234B)12C)123D)1234(16)以i关于C语言数据类型使用的叙述中错误的是A)若要准确无误差的表示自然数,应使用整数类型B)若要保存带有多位小数的数据,应使用双精度类型C)若要处理如“人员信息”等含有不同类型的相关数据,应自定义结构体类型D)若只处理“真”和“假”两种逻辑值,应使用逻辑类型(17)若a是数值类型,则逻辑表达式(a=1)|(a!=1)的值是A)1B)0C)2D)不知道a的值,不能确定(18)以下选项中与if(a=1)a=b; else a+;语句功能不同的switch语句
6、是A)switch(a)case:a=b;break;default:a+;B)switch(a=1)case 0:a=b;break;case 1:a+;C)switch(a)default:a+;break;case 1:a=b;D)switch(a=1)case 1:a=b;break;case 0:a+;(19)有如下嵌套的if语句if (aif(aelse k=c;elseif(belse k=c;以下选项中与上述if语句等价的语句是A)k=(aB)k=(ac)?b:c);C)k=(aD)k=(a(20)有以下程序#includemain()in i,j,m=1;for(i=1;iO
7、;j-)if(i*j)3)break;m=i*j;printf(m=%dn,m);程序运行后的输出结果是A)m=6B)m=2C)m=4D)m=5(21)有以下程序#include(stdio.hmain()int a=l;b=2;for(;a8;a+) b+=a;a+=2;printf(%d,%dn,a,b);程序运行后的输出结果是A)9,18B)8,11C)7,11D)10,14(22)有以下程序,其中k的初值为八进制数#includemain()int k=011;printf(%dn,k+);程序运行后的输出结果是A)12B)11C)10D)9(23)下列语句组中,正确的是A)char
8、*s;s=Olympic;B)char s7;s=Olympic;C)char *s;s=Olympic;D)char s7;s=Olympic;(24)以下关于return语句的叙述中正确的是A)一个自定义函数中必须有一条return语句B)一个自定义函数中可以根据不同情况设置多条return语句C)定义成void类型的函数中可以有带返回值的return语句D)没有return语句的自定义函数在执行结束时不能返回到调用处(25)下列选项中,能正确定义数组的语句是A)int num0.2008;B)int num;C)int N=2008;int numN;D)#define N 2008in
9、t numN;(26)有以下程序#includevoid fun(char *c,int d)*c=*c+1;d=d+1;printf(%c,%c,*c,d);main()char b=a,a=A;fun(&b,a);printf(%e,%en,b,a);程序运行后的输出结果是A)b,B,b,AB)b,B,B,AC)a,B,B,aD)a,B,a,B(27)若有定义int(*Pt)3;,则下列说法正确的是A)定义了基类型为int的三个指针变量B)定义了基类型为int的具有三个元素的指针数组ptC)定义了一个名为*pt、具有三个元素的整型数组D)定义了一个名为pt的指针变量,它可以指向每行有三个整
10、数元素的二维数组(28)设有定义double a10,*s=a;,以下能够代表数组元素a3的是A)(*s)3B)*(s+3)C)*s3D)*s+3(29)有以下程序#include(stdio.h)main()int a5=1,2,3,4,5,b5=O,2,1,3,0,i,s=0;for(i=0;i5;i+) s=s+abi);printf(%dn, s);程序运行后的输出结果是A)6B)10C)11D)15(30)有以下程序#includemain()int b 33=O,1,2,0,1,2,O,1,2,i,j,t=1;for(i=0;i3;i+)for(j=ij0) return tn-1
11、+f(t,n-1);else return 0;程序运行后的输出结果是A)4B)1OC)14D)6(34)有以下程序#includeint fun() static int x=1;x*2; return x;main()int i,s=1,for(i=1;iyear=1980;D)w.s.year=1980;(39)有以下程序#includemain() int a=2,b=2,c=2;printf(%dn,a/b&c);程序运行后的输出结果是A)OB)1C)2D)3(40)有以下程序#includemain() FILE *fp;char str10;fp=fopen(myfile.dat
12、,w);fputs(abc,fp);fclose(fp);fpfopen(myfile.data,a+);fprintf(fp,%d,28);rewind(fp);fscanf(fp,%s,str); puts(str);fclose(fp);程序运行后的输出结果是A)abcB) 28cC) abc28D)因类型不一致而出错二、填空题(1)一个队列的初始状态为空。现将元素A,B,C,D,E,F,5,4,3,2,1依次入队,然后再依次退队,则元素退队的顺序为【1】 。(2)设某循环队列的容量为50,如果头指针front=45(指向队头元素的前一位置),尾指针rear=10(指向队尾元素),则该循
13、环队列中共有【2】 个元素。(3)设二叉树如下:对该二叉树进行后序遍历的结果为 【3】 。(4)软件是 【4】 、数据和文档的集合。(5)有一个学生选课的关系,其中学生的关系模式为:学生(学号,姓名,班级,年龄),课程的关系模式为:课程(课号,课程名,学时),其中两个关系模式的键分别是学号和课号,则关系模式选课可定义为:选课(学号,【5】 ,成绩)。(6)设x为int型变量,请写出一个关系表达式 【6】 ,用以判断x同时为3和7的倍数时,关系表达式的值为真。(7)有以下程序#includemain() int a=1,b=2,c=3,d=0;if(a=1)if(b!=2)if(c=3) d=1
14、;else d=2;else if(c!=3) d=3;else d=4;else d=5;printf(“%dn”,d);程序运行后的输出结果是 【7】 。(8)有以下程序#includemain() int m,n;scanf(%d%d,&m,&n);while(m!=n) while(mn) m=m-n;while(mprintf(“%dn”,m);程序运行后,当输入14 63 时,输出结果是 【8】。(9)有以下程序#includemain() int i,j,a3=1,2,3,4,5,6,7,8,9;for(i=0;i3;i+)for(j=i;j3;j+) printf(“%d%,a
15、ij);printf(n);程序运行后的输出结果是 【9】 。(10)有以下程序#includemain() int a=1,2,3,4,5,6,*k3,i=0;while(i3) ki=&a2*i;printf(%d,*ki);i+;程序运行后的输出结果是 【10】 。(11)有以下程序#includemain() int a33=1,2,3,4,5,6,7,8,9;int b3=0,i;for(i=0;i3;i+) bi=ai2+a2i;for(i=0;i0;i-) stri=stri-1;str0=temp;main() char s50;scanf(%s,s); fun(s); pri
16、ntf(%sn,s);程序运行后输入:abcdef,则输出结果是 【12】。(13)以下程序的功能是:将值为三位正整数的变量x中的数值按照个位、十位、百位的顺序拆分并输出。请填空。#includemain() int x=256;printf(%d-%d-%dn, 【13】 ,x/10%10,x/100);(14)以下程序用以删除字符串所有的空格,请填空。#includemain() 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”
17、,s);(15)以下程序的功能是:借助指针变量找出数组元素中的最大值及其元素的下标值。请填空。#includemain() int a10,*p,*s;for(p=a;p-a10;p+) scanf(%d,p);for(p=a,s=a;p-a*s) s= 【15】 ;printf(“index=%dn”,s-a);更多内容请参考:2010年9月计算机等级考试二级C语言真题试卷一、选择题(每小题2分,共70分)下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的。请将正确选项填涂在答题卡相应位置上,答在试卷上不得分。(1)下列叙述中正确的是A)线性表的链式结构与顺序存储结构所需要的存储
18、空间是相同的B)线性表的链式存储结构所需要的存储空间一般要多于顺序存储结构C)线性表的链式存储结构所需要的存储空间一般要少于顺序存储结构D)上述三种说法都不对(2)下列叙述中正确的是A)在栈中,栈中元素随栈底指针与栈顶指针的变化而动态变化B)在栈中,栈顶指针不变,栈中元素随栈底指针的变化而动态变化C)在栈中,栈底指针不变,栈中元素随栈顶指针的变化而动态变化D)上述三种说法都不对(3)的目的是A)评估软件可靠性B)发现并改正程序中的错误C)改正程序中的错误D)发现程序中的错误(4)下面描述中,不属于软件危机表现的是A)软件过程不规范B)软件开发生产率低C)软件质量难以控制D)软件成本不断提高(5
19、)软件生命周期是指A)软件产品从提出、实现、使用维护到停止使用退役的过程B)软件从需求分析、设计、实现到测试完成的过程C)软件的开发过程D)软件的运行维护过程(6)面向对象方法中,继承是指A)一组对象所具有的相似性质B)一个对象具有另一个对象的性质C)各对象之间的共同性质D)类之间共享属性和操作的机制(7)层次型、网状型和关系型数据库划分原则是A)记录长度B)文件的大小C)联系的复杂程度D)数据之间的联系方式(8)一个工作人员可以使用多台计算机,而一台计算机可被多个人使用,则实体工作人员、与实体计算机之间的联系是A)一对一B)一对多C)多对多D)多对一(9)数据库设计中反映用户对数据要求的模式
20、是A)内模式B)概念模式C)外模式D)设计模式(10)有三个关系R、S和T如下:则由关系R和S得到关系T的操作是A)自然连接B)交C)投影D)并一、 (11)以下关于结构化程序设计的叙述中正确的是A)一个结构化程序必须同时由顺序、分支、循环三种结构组成B)结构化程序使用goto语句会很便捷C)在中,程序的模块化是利用函数实现的D)由三种基本结构构成的程序只能解决小规模的问题(12)以下关于简单程序设计的步骤和顺序的说法中正确的是A)确定算法后,整理并写出文档,最后进行编码和上机调试B)首先确定,然后确定算法,再编码,并上机调试,最后整理文档C)先编码和上机调试,在编码过程中确定算法和数据结构,
21、最后整理文档D)先写好文档,再根据文档进行编码和上机调试,最后确定算法和数据结构(13)以下叙述中错误的是A) C程序在运行过程中所有计算都以二进制方式进行B)C程序在运行过程中所有计算都以十进制方式进行C)所有C程序都需要编译链接无误后才能运行D)C程序中整型变量只能存放整数,实型变量只能存放浮点数(14)有以下定义:int a; long b; double x,y;则以下选项中正确的表达式是A)a%(int)(x-y)B)a=x!=y;C)(a*y)%bD)y=x+y=x(15)以下选项中能表示合法常量的是A)整数:1,200B)实数:1.5E2.0C )字符斜杠:D)字符串:007(1
22、6)表达式a+=a-=a=9的值是A)9B)_9C)18D)0(17)若变量已正确定义,在if (W)printf(“%dn,k”);中,以下不可替代W的是A)ab+cB)ch=getchar()C)a=b+cD)a+(18)有以下程序includemain()int a=1,b=0;if(!a) b+;else if(a=0)if(a)b+=2;else b+=3;printf(”%dn”,b);程序运行后的输出结果是A)0B)1C)2D)3(19)若有定义语句int a, b;double x;则下列选项中没有错误的是A)switch(x%2) B)switch(int)x/2.0case
23、 0: a+; break; case 0: a+; break;case 1: b+; break; case 1: b+; break;default : a+; b+; default : a+; b+; C)switch(int)x%2) D)switch(int)(x)%2)case 0: a+; break; case 0.0: a+; break;case 1: b+; break; case 1.0: b+; break;default : a+; b+; default : a+; b+; (20)有以下程序include main()int a=1,b=2;while(am
24、ain()int y=10;while(y-);printf(”Y=dn”,Y);程序执行后的输出结果是A)y=0B)y= -1C)y=1D)while构成无限循环(22)有以下程序includestdio .hmain()char s”rstuv;printf(”cn”,*s2);程序运行后的输出结果是A)tuvB)字符t的ASCII码值C)tD)出错(23)有以下程序includestdio.hincludestring.hmain()char x”STRING”;x0=0;x10;x20;printf(”d dn”,sizeof(x),strlen(x);程序运行后的输出结果是A)6 1
25、B)7 0C)6 3D)7 1(24)有以下程序includestdiohInt f(int x);main()int n=1,m;m=f(f(f(n);printf(”%dn”,m);int f(int x)return x*2;程序运行后的输出结果是A)1B)2C)4D)8(25)以下程序段完全正确的是A)int *p; scanf(%d,p);B)int *p; scanf(“%d”,p);C)int k, *p=&k; scanf(%d,p);D)int k, *p:; *p= &k; scanf(“%d”,p);(26)有定义语句:int *p4;以下选项中与此语句等价的是A)int
26、 p4;B)int *p;C)int *(p4);D)int (*p)4;(27)下列定义数组的语句中,正确的是A)int N=10; B)define N 10int xN; int xN;C)int x0.10; D)int x;(28)若要定义一个具有5个元素的整型数组,以下错误的定义语句是A)int a5=0;B)int b=0,0,0,0,0;C)int c2+3;D)int i=5,di;(29)有以下程序includestdiohvoid f(int *p);main()int a51,2,3,4,5,*r=a;f(r);printf(”dn”;r);void f(int *p)
27、p=p+3;printf(”d,”,*p);程序运行后的输出结果是A)1,4B)4,4C)3,1D)4,1(30)有以下程序(函数fun只对下标为偶数的元素进行操作)# includestdiohvoid fun(inta;int n)int i、j、k、t;for (i=0;in一1;1=2)k=i;for(j=i;jak)k=j;t=ai;ai=ak;akt;main()int aa10=1、2、3、4、5、6、7,i;fun(aa、7);for(i=0,iincludestring hmain()char a20=”ABCDOEFG0”,b”IJK”;strcat(a,b);printf
28、(”sn”,a);程序运行后的输出结果是A)ABCDEOFGOIJKB)ABCDIJKC)IJKD)EFGIJK(34)有以下程序,程序中库函数islower (ch)用以判断ch中的字母是否为小写字母includestdiohincludectypehvoid fun(charp)int i=0;while (pi)if(pi= islower(pi-1)pi-1=pi-1-a+A;i;main()char s1100”ab cd EFG!”;fun(s1); printf(”sn”,s1);程序运行后的输出结果是A)ab cd EFG!B)Ab Cd EFg!C)aB cD EFG!D)a
29、b cd EFg!35)有以下程序includestdiohvoid fun(int x)if(x21)fun(x2);printf(”d”,x);main()fun(7);printf(”n”);程序运行后的输出结果是A)1 3 7B)7 3 1C)7 3D)3 7(36)有以下程序includestdiohint fun()static int x=1;x+=1;return x;main()int i;s=1;for(i=1;imain()int s,t,A=10;double B=6;ssizeof(A);t=sizeof(B);printf(“d,dn”,s,t);在VC6上编译运行
30、,程序运行后的输出结果是A)2,4 B)4,4 C)4,8 D)10,6(39)若有以下语句Typedef struct Sint g; char h;T;以下叙述中正确的是A)可用S定义结构体变量B)可用T定义结构体变量C)S是struct类型的变量D)T是struct S类型的变量(40)有以下程序includestdiohmain()short c=124;c=c_;printf(“dn”、C);若要使程序的运行结果为248,应在下划线处填入的是A)2 B)|248 C)0248 D)I二、填空题(每空2分,共30分)请将每空的正确答案写在答题卡【1】至【15】序号的横线上,答在试卷上不得分。(1)一个栈的初始状态为空。首先将元素5,4,3,2,1依次入栈,然后退栈一次,再将元素 A,B,C,D依次入栈,之后将所有元素全部退栈