2009 年 9 月二级C笔试真题及答案
2009年9月全国计算机等级考试笔试试卷二级公共基础知识和C语言程序设计(考试时间90分钟,满分100分)一、选择题((1)~(10)、(21)~(40)每题2分,(11)~(20)每题1分,70分)(1)下列数据结构中,属于非线性结构的是()。A)循环队列B)带链队列C)二叉树D)带链栈(2)下列数据结构中,能够按照“先进后出”原则存取数据的是()。A)循环队列B)栈C)队列D)二叉树(3)对于循环队列,下列叙述中正确的是()。A)队头指针是固定不变的B)队头指针一定大于队尾指针C)队头指针一定小于队尾指针D)队头指针可以大于队尾指针,也可以小于队尾指针(4)算法的空间复杂度是指()。A)算法在执行过程中所需要的计算机存储空间B)算法所处理的数据量C)算法程序中的语句或指令条数D)算法在执行过程中所需要的临时工作单元数(5)软件设计中划分模块的一个准则是()。A)低内聚低耦合B)高内聚低耦合C)低内聚高耦合D)高内聚高耦合(6)下列选项中不属于结构化程序设计原则的是()。A)可封装B)自顶向下C)模块化D)逐步求精(7)软件详细设计产生的图如下:beginYX=0Nb=ac=aend该图是()。A)N-S图B)PAD图C)程序流程图D)E-R图(8)数据库管理系统是()。A)操作系统的一部分B)在操作系统支持下的系统软件C)一种编译系统D)一种操作系统(9)在E-R图中,用来表示实体联系的图形是()。A)椭圆形B)矩形C)菱形D)三角形(10)有三个关系R,S和T如下:9nABCd32ABCa12b21c31d32RSTABCa12b21c31其中关系T由关系R和S通过某种操作得到,该操作为()。A)选择B)投影C)交D)并(11)以下叙述中正确的是()。A)程序设计的任务就是编写程序代码并上机调试B)程序设计的任务就是确定所用数据结构C)程序设计的任务就是确定所用算法D)以上三种说法都不完整(12)以下选项中,能用作用户标识符的是()。A)voidB)8_8C)_0_D)unsigned(13)阅读以下程序#include
main(){intcase;floatprintF;printf("请输入2个数:");scanf("%d%f",&case,&printF);printf("%d%fn",case,printF);}该程序在编译时产生错误,其出错原因是()。A)定义语句出错,case是关键字,不能用作用户自定义标识符B)定义语句出错,printF不能用作用户自定义标识符C)定义语句无错,scanf不能作为输入函数使用D)定义语句无错,printf不能输出case的值(14)表达式:(int)((double)9/2)-(9)%2的值是()。A)0B)3C)4D)5(15)若有定义语句:intx=10;,则表达式x-=x+x的值为()。A)-20B)-10C)0D)10(16)有以下程序#includemain(){inta=l,b=0;printf("%d,",b=a+b);printf("%dn",a=2*b);}程序运行后的输出结果是()。A)0,0B)1,0C)3,2D)1,2(17)设有定义:inta=l,b=2,c=3;,以下语句中执行效果与其它三个不同的是()。A)if(a>b)c=a,a=b,b=c;B)if(a>b){c=a,a=b,b=c;}C)if(a>b)c=a;a-b;b=c;D)if(a>b){c=a;a-b;b=c;}(18)有以下程序#include9nABCd32ABCa12b21c31d32RSTABCa12b21c31其中关系T由关系R和S通过某种操作得到,该操作为()。A)选择B)投影C)交D)并(11)以下叙述中正确的是()。A)程序设计的任务就是编写程序代码并上机调试B)程序设计的任务就是确定所用数据结构C)程序设计的任务就是确定所用算法D)以上三种说法都不完整(12)以下选项中,能用作用户标识符的是()。A)voidB)8_8C)_0_D)unsigned(13)阅读以下程序#includemain(){intcase;floatprintF;printf("请输入2个数:");scanf("%d%f",&case,&printF);printf("%d%fn",case,printF);}该程序在编译时产生错误,其出错原因是()。A)定义语句出错,case是关键字,不能用作用户自定义标识符B)定义语句出错,printF不能用作用户自定义标识符C)定义语句无错,scanf不能作为输入函数使用D)定义语句无错,printf不能输出case的值(14)表达式:(int)((double)9/2)-(9)%2的值是()。A)0B)3C)4D)5(15)若有定义语句:intx=10;,则表达式x-=x+x的值为()。A)-20B)-10C)0D)10(16)有以下程序#includemain(){inta=l,b=0;printf("%d,",b=a+b);printf("%dn",a=2*b);}程序运行后的输出结果是()。A)0,0B)1,0C)3,2D)1,2(17)设有定义:inta=l,b=2,c=3;,以下语句中执行效果与其它三个不同的是()。A)if(a>b)c=a,a=b,b=c;B)if(a>b){c=a,a=b,b=c;}C)if(a>b)c=a;a-b;b=c;D)if(a>b){c=a;a-b;b=c;}(18)有以下程序#include9nmain(){intc=0,k,for(k=1;k<3;k++)switch(k){default:c+=k;case2:c++;break;case4:c+=2;break;}printf("%dn",c);}程序运行后的输出结果是()。A)3B)5C)7D)9(19)以下程序段中,与语句:k=a>b?(b>c?1:0):0;功能相同的是()。A)if((a>b)&&(b>c))k=l;B)if((a>b)||(b>c))k=l;elsek=0;elsek=0;C)if(a<=b)k=0;D)if(a>b)k=l;elseif(b<=c)k=1;elseif(b>c)k=1;elsek=0;(20)有以下程序#includemain(){chars[]={"012xy"};inti,n=0;for(i=0;s[i]!=0;i++)if(S[i]>='a'&&s[i]<='z')n++;printf("%dn",n);}程序运行后的输出结果是()。A)0B)2C)3D)5(21)有以下程序#includemain(){intn=2,k=0;while(k++&&n++>2);printf("%d%dn",k,n);}程序运行后的输出结果是()。A)02B)13C)57D)l2(22)有以下定义语句,编译时会出现编译错误的是()。A)chara='a';B)chara='n';C)chara='aa';D)chara='x2d';(23)有以下程序#includemain(){charc1,c2;c1='A'+'8'-'4';c2='A'+'8'-'5';printf("%c,%dn",c1,c2);9n}已知字母A的ASCII码为65,程序运行后的输出结果是()。A)E,68B)D,69C)E,DD)输出无定值(24)有以下程序#includevoidfun(intp){intd=2;p=d++;printf("%d",p);}main(){inta=1;fun(a);printf("%dn",a);}程序运行后的输出结果是()。A)32B)12C)21D)22(25)以下函数findmax拟实现在数组中查找最大值并作为函数值返回,但程序中有错导致不能实现预定功能。#defineMIN-2147483647intfindmax(intx[],intn){inti,max;for(i=0;imain(){intm=1,n=2,*p=&m,*q=&n,*r;r=p;p=q;q=r;printf("%d,%d,%d,%dn",m,n,*p,*q);}程序运行后的输出结果是()。A)1,2,1,2B)1,2,2,1C)2,1,2,1D)2,1,1,2(27)若有定义语句:inta[4][10],*p,*q[4];且0≤i<4,则错误的赋值是()。A)p=aB)q[i]=a[i]C)p=a[i]D)p=&a[2][1](28)有以下程序#include#includemain(){charstr[][20]={"One*World","One*Dream!"},*p=str[1];printf("%d,",strlen(p));printf("%sn",p);}9n程序运行后的输出结果是()。A)9,One*WorldB)9,One*Dream!C)10,One*Dream!D)10,One*World(29)有以下程序#includemain(){inta[]={2,3,5,4},i;for(i=0;i<4;i++)switch(i%2){case0:switch(a[i]%2){case0:a[i]++;break;case1:a[i]--;}break;case1:a[i]=0;}for(i=0;i<4;i++)printf("%d",a[i]);printf("n");}程序运行后的输出结果是()。A)3344B)2050C)3040D)0304(30)有以下程序#include#includemain(){chara[10]="abcd";printf("%d,%dn",strlen(a),sizeof(a));}程序运行后的输出结果是()。A)7,4B)4,10C)8,8D)10,10(31)下面是有关C语言字符数组的描述,其中错误的是()。A)不可以用赋值语句给字符数组名赋字符串B)可以用输入语句把字符串整体输入给字符数组C)字符数组中的内容不一定是字符串D)字符数组只能存放字符串(32)下列函数的功能是()。fun(char*a,char*b){while((*b=*a)!=' '){a++;b++;}}A)将a所指字符串赋给b所指空间B)使指针b指向a所指字符串C)将a所指字符串和b所指字符串进行比较D)检查a和b所指字符串中是否有' '(33)设有以下函数:voidfun(intn,char*s){……}则下面对函数指针的定义和赋值均正确的是()。A)void(*pf)();pf=fun;B)void*pf();pf=fun;C)void*pr();*pf=fun;D)void(*pf)(int,char);pf=&fun;(34)有以下程序#include9nintf(intn);main(){inta=3,s;s=f(a);s=s+f(a);printf("%dn",s);}intf(intn){staticinta=1;n+=a++;returnn;}程序运行后的输出结果是()。A)7B)8C)9D)10(35)有以下程序#include#definef(x)x*x*xmain(){inta=3,s,t;s=f(a+1);t=f((a+1));printf("%d,%dn",s,t);}程序运行后的输出结果是()。A)10,64B)10,10C)64,10D)64,64(36)下面结构体的定义语句中,错误的是()。A)structord{intx;inty;intz;};structorda;B)structord{intx;inty;intz;}structorda;C)structord{intx;inty;intz;}a;D)struct{intx;inty;intz;}a;(37)设有定义:char*c;,以下选项中能够使字符型指针c正确指向一个字符串的是()。A)charstr[]="string";c=str;B)scanf("%s",c);C)c=getchar();D)*c=*string";(38)有以下程序#include#includeStructA{inta;charb[10];doublec;};structAf(structAt);main(){structAa={1001,"ZhangDa",1098.0};a=f(a);printf("%d,%s,%6.1fn",a.a,a.b,a.c);}structAf(StructAt){t.a=1002;strcpy(t.b,"ChangRong");t.c=1202.0;returnt;}程序运行后的输出结果是()。A)1001,ZhangDa,1098.0B)1002,ZhangDa,1202.0C)1001,ChangRong,1098.0D)1002,ChangRong,1202.0(39)若有以下程序段9nintr=8;printf("%dn",r>>1);输出结果是()。A)16B)8C)4D)2(40)下列关于C语言文件的叙述中正确的是()。A)文件由一系列数据依次排列组成,只能构成二进制文件B)文件由结构序列组成,可以构成二进制文件或文本文件C)文件由数据序列组成,可以构成二进制文件或文本文件D)文件由字符序列组成,其类型只能是文本文件二、填空题(每空2分,共30分)(1)某二叉树有5个度为2的结点以及3个度为1的结点,则该二叉树中共有【1】个结点。(2)程序流程图中的菱形框表示的是【2】。(3)软件开发过程主要分为需求分析、设计、编码与测试四个阶段,其中【3】阶段产生“软件需求规格说明书”。(4)在数据库技术中,实体集之间的联系可以是一对一或一对多或多对多的,那么“学生”和“可选课程”的联系为【4】。(5)人员基本信息一般包括:身份证号,姓名,性别,年龄等。其中可以作为主关键字的是【5】。(6)若有定义语句:inta=5;,则表达式:a++的值是【6】。(7)若有语句doublex=17;inty;,当执行y=(int)(x/5)%2;之后y的值为【7】。(8)以下程序运行后的输出结果是【8】。#includemain(){intx=20;printf("%d",0main(){inta=1,b=7;do{b=b/2;a+=b;}while(b>1);printf("%dn",a);}(10)有以下程序#includemain(){intf,fl,f2,i;f1=0;f2=1;printf("%d%d",fl,f2);for(i=3;i<=5;i++){f=fl+f2;printf("%d",f);f1=f2;f2=f;}printf("n");}程序运行后的输出结果是【10】。9n(11)有以下程序#includeinta=5;voidfun(intb){inta=10;a+=b;printf("%d",a);}main(){intc=20;fun(c);a+=c;printf("%dn",a);}程序运行后的输出结果是【11】。(12)设有定义:structperson{intID;charname[12];}p;请将scanf("%d",【12】);语句补充完整,使其能够为结构体变量p的成员ID正确读入数据。(13)有以下程序#includemain(){chara[20]="Howareyou?",b[20];scanf("%s",b);printf("%s%sn",a,b);}程序运行时从键盘输入:Howareyou?<回车>则输出结果为【13】。(14)有以下程序#includetypedefstruct{intnum;doubles;}REC;voidfunl(RECx){x.num=23;x.s=88.5;}main(){RECa={16,90.0};funl(a);printf("%dn",a.num);}程序运行后的输出结果是【14】。(15)有以下程序#includefun(intx){if(x/2>0)fun(x/2);printf("%d",x);}main(){fun(6);printf("n");}程序运行后的输出结果是【15】。9n2009年9月笔试试卷参考答案一、选择题(1)C)(2)B)(3)D)(4)A)(5)B)(6)A)(11)D)(16)D)(21)D)(26)B)(31)D)(36)B)二、填空题(7)C)(12)C)(17)C)(22)C)(27)A)(32)B)(37)A)(8)B)(13)A)(18)A)(23)A)(28)C)(33)D)(38)D)(9)C)(14)B)(19)A)(24)C)(29)C)(34)C)(39)C)(10)D)(15)B)(20)A)(25)D)(30)B)(35)A)(40)C)(1)14(2)逻辑判断(3)需求分析(4)多对多(5)身份证号(6)5(7)1(8)10(9)5(10)01123(11)3025(12)p.ID(13)Howareyou?How(14)16(15)036