2006年9月全国计算机等级考试二级C语言试卷(含答案)
2006年9月全国计算机等级考试二级笔试试卷C语言程序设计(考试时间120分钟,满分100分)一,选择题((1)-(10)每题2分,(11)-(50)每题1分,共60分)(1)下列选项中不符合良好程序设计风格的是A源程序要文档化 B数据说明的次序要规范化C避免滥用goto语句D模块设计要保证高耦合,高内聚(2)从工程管理角度,软件设计一般分为两步完成,它们是A概要设计与详细设计 B数据设计与接口设计C软件结构设计与数据设计D过程设计与数据设计(3)下列选项中不属于软件生命周期开发阶段任务的是A软件测试B概要设计C软件维护D详细设计(4)在数据库系统中,用户所见的数据模式为A概念模式B外模式C内模式 D物理模式(5)数据库设计的四个阶段是:需求分析,概念设计,逻辑设计和A编码设计B测试阶段C运行阶段D物理设计(6)设有如下三个关系表 下列操作中正确的是AT=R∩SBT=RỦSCT=R×SDT=R/S(7)下列叙述中正确的是A一个算法的空间复杂度大,则其时间复杂度也必定大Bn一个算法的空间复杂度大,则其时间复杂度必定小C一个算法的时间复杂度大,则其空间复杂度必定小D上述三种说法都不对(8)在长度为64的有序线性表中进行顺序查找,最坏情况下需要比较的次数为A63 B64 C6 D7(9)数据库技术的根本目标是要解决数据的A存储问题B共享问题C安全问题D保护问题(10)对下列二*树进行中序遍历的结果是AACBDFEGBACBDFGECABDCGEFDFCADBEG(11)下列叙述中错误的是A一个C语言程序只能实现一种算法BC程序可以由多个程序文件组成CC程序可以由一个或多个函数组成D一个C函数可以单独作为一个C程序文件存在(12)下列叙述中正确的是A每个C程序文件中都必须要有一个main()函数B在C程序中main()函数的位置是固定的CC程序中所有函数之间都可以相互调用,与函数所在位置无关Dn在C程序的函数中不能定义另一个函数(13)下列定义变量的语句中错误的是Aint_int;Bdoubleint_;CcharFor;DfloatUS$(14)若变量x,y已正确定义并赋值,以下符合C语言语法的表达式是A++x,y=x--Bx+1=yCx=x+10=x+yDdouble(x)/10(15)以下关于逻辑运算符两侧运算对象的叙述中正确的是A只能是整数0或1B只能是整数0或非0整数C可以是结构体类型的数据D可以是任意合法的表达式(16)若有定义intx,y;并已正确给变量赋值,则以下选项中与表达式(x-y)?(x++):(y++)中的条件表达式(x-y)等价的是A(x-y>0)B(x-y<0)C(x-y<0||x-y>0)D(x-y==0)(17)有以下程序main(){intx,y,z; x=y=1; z=x++,y++,++y; printf("%d,%d,%dn",x,y,z);}程序运行后的输出结果是A2,3,3B2,3,2C2,3,1D2,2,1(18)设有定义inta;floatb;执行scanf("%2d%f",&a,&b);语句时,若从键盘输入876543.0<回车>,a和b的值分别是A876和543.000000B87和6.000000C87和543.000000 D76和543.000000(19)有以下程序main(){intna=0,b=0; a=10; /*给a赋值 b=20; 给b赋值 */ printf("a+b=%dn",a+b);/*输出计算结果*/}程序运行后的输出结果是Aa+b=10Ba+b=30C30D出错(20)在嵌套使用if语句时,C语言规定else总是A和之前与其具有相同缩进位置的if配对B和之前与其最近的if配对C和之前与其最近不带else的if配对D和之前的第一个if配对(21)下列叙述中正确的是Abreak语句只能用于switch语句B在switch语句中必须使用defaultCbreak语句必须与switch语句中的case配对使用D在switch语句中不一定使用break语句(22)有以下程序main(){intk=5; while(--k)printf("%d",k-=3); printf("n");}执行后的输出结果是A1 B2 C4 Dn死循环(23)有以下程序main(){inti; for(i=1;i<=40;i++) {if(i++%5==0) if(++i%8==0)printf("%d",i); } printf("n");}执行后的输出结果是A5 B24 C32 D40(24)以下选项中值为1的表达式是A1-'0' B1-' ' C'1'-0 D' '-'0'(25)有以下程序fun(intx,inty){return(x+y);}main(){inta=1,b=2,c=3,sum; sum=fun((a++,b++,a+b),c++); printf("%d",sum);}执行后的输出结果是A6 B7 C8 D9(26)有以下程序main(){charns[]="abcde"; s+=2; printf("%dn",s[0]);}执行后的结果是A输出字符a的ASCII码 B输出字符c的ASCII码C输出字符c D程序出错(27)有以下程序fun(intx,inty){staticintm=0,i=2; i+=m+1;m=i+x+y;returnm;}main(){intj=1,m=1,k; k=fun(j,m); printf("%d,",k); k=fun(j,m); printf("%dn",k);}执行后的输出结果是A5,5B5,11C11,11D11,5(28)有以下程序fun(intx){intp; if(x==0||x==1)return(3); p=x-fun(x-2); returnnp;}main(){printf("%dn",fun(7));}执行后的输出结果是A7 B3 C2 D0(29)在16位编译系统上,若有定义inta[]={10,20,30},*p=&a;,当执行p++后,下列说法错误的是Ap向高地址移了一个字节 Bp向高地址移了一个存储单元Cp向高地址移了两个字节 Dp与a+1等价(30)有以下程序main(){inta=1,b=3,c=5; int*p1=&a,*p2=&b,*p=&c; *p=*p1*(*p2); printf("%dn",c);}执行后的输出结果是A1 B2 C3 D4(31)若有定义:intw[3][5];,则以下不能正确表示该数组元素的表达式是A*(*w+3) B*(w+1)[4] C*(*(w+1)) D*(&w[0][0]+1)(32)若有以下函数首部intfun(doublex[10],int*n)则下面针对此函数的函数声明语句中正确的是Aintfun(doublex,int*n); Bintfun(double,int);Cintfun(double*x,intn); Dintfun(double*,int*);(33)若有定义语句:intk[2][3],*pk[3];,则以下语句中正确的是Apk=k; Bpk[0]=&k[1][2]; Cpk=k[0]; Dnpk[1]=k;(34)有以下程序voidchange(intk[]){k[0]=k[5];}main(){intx[10]={1,2,3,4,5,6,7,8,9,10},n=0; while(n<=4){change(&x[n]);n++;} for(n=0;n<5;n++)printf("%d",x[n]); printf("n");}程序运行后的输出结果是A678910 B13579 C12345 D62345(35)若要求定义具有10个int型元素的一维数组a,则以下定义语句中错误的是A#defineN10 B#definen5 inta[N]; inta[2*n];Cinta[5+5]; Dintn=10,a[n];(36)有以下程序main(){intx[3][2]={0},i; for(i=0;i<3;i++)scanf("%d",x[i]);printf(“%3d%3d%3d”,x[0][0],x[0][1],x[1][0]);}若运行时输入:246<回车>,则输出结果为A200 B204 C240 D246(37)有以下程序main(){charns[]={"aeiou"},*ps; ps=s;printf("%cn",*ps+4);}程序运行后的输出结果是Aa Be Cu D元素s[4]的地址(38)以下语句中存在的语法错误是Acharss[6][20];ss[1]="right?";Bcharss[][20]={"right?"};Cchar*ss[6]; ss[1]="right?";Dchar*ss[]={"right?"};(39)若有定义:char*x="abcdefghi";,以下选项中正确运用了strcpy函数的是Achary[10];strcpy(y,x[4]);Bchary[10];strcpy(++y,&x[1]);Cchary[10],*s;strcpy(s=y+5,x);Dchary[10],*s;strcpy(s=y+1,x+1);(40)有以下程序intadd(inta,intb){return(a+b);}main(){intk,(*f)(),a=5,b=10; f=add; …}则以下函数调用语句错误的是Ak=(*f)(a,b); Bk=add(a,b);Ck=*f(a,b); Dnk=f(a,b);(41)有以下程序#include
main(intargc,char*argv[]){inti=1,n=0; while(i#defineN5#defineMN+1 n#definef(x)(x*M)main(){inti1,i2; i1=f(2); i2=f(1+1); printf("%d %d",i1,i2);}程序的运行结果是A12 12 B11 7 C11 11 D12 7(44)役有以下语句typedefstructTT{charc; inta[4];}CIN;则下列叙述正确的是A可以用TT定义结构体变量 BTT是struct类型的变量C可以用CIN定义结构体变量 DCIN是structTT类型的变量 (45)有以下结构体说明,变量定义和赋值语句structSTD{charname[10]; intage; char***;}s[5],*ps;ps=&s[0];则以下scanf函数调用语句中错误的结构体变量成员的是Ascanf("%s",s[0].name); Bscanf("%d",&s[0].age);Cscanf("%c",&(ps->***));Dnscanf("%d",ps->age);(46)有以下定义和语句uniondata{inti;charc;floatf;}x;inty;则以下语句中正确的是Ax=10.5Bx.c=101Cy=xDprintf("%dn",x);(47)程序中已构成如下图所示的不带头结点的单向链表结构指针变量s,p,q均已正确定义,并用于指向链表结点,指针变量s总是作为头指针指向链表的第一个结点.若有以下程序段q=s;s=s->next;p=s;while(p->next)p=p->next;p->next=q;q->next=NULL;该程序段实现的功能是A首结点成为尾结点 B尾结点成为首结点C删除首结点 D删除尾结点(48)若变量已正确定义,则以下语句的输出结果是 s=32; s^=32; printf("%d",s);A-1 B0 C1 D32(49) 以下叙述正确的是AC语言中的文件是流式文件,因此只能顺序存取数据B打开一个已存在的文件并进行了写操作后,原有文件中的全部数据必定被覆盖C在一个程序中当对文件进行了写操作后,必须先关闭该文件然后再打开,才能读到第一个数据Dn当对文件的读(写)操作完成之后,必须将它关闭,否则可能导致数据丢失(50)有以下程序#includemain(){FILE*fp; inti; charch[]="abcd",t; fp=fopen("abc.dat","wb+"); for(i=0;i<4;i++)fwrite(&ch[i],1,1,fp); fseek(fp,-2L,SEEK_END); fread(&t,1,1,fp); fclose(fp); printf("%c",t);}程序执行后的输出结果是Ad Bc Cb Da二,填空题(每空2分,共40分) 请将每一个空的正确答案写在答题卡[1]-[20]序号的横线上,答在试卷上不得分.(1) 下列软件系统结构图的宽度为[1].(2)[2]的任务是诊断和改正程序中的错误.(3)一个关系表的行称为[3].(4)按"先进后出"原则组织数据的数据结构是[4].(5)数据结构分为线性数据结构和非线性数据结构,带链的队列属于[5].(6)设有定义:floatnx=123.4567;,则执行以下语句后的输出结果是[6]. printf("%fn",(int)(x*100+0.5)/100.0);(7)以下程序运行后的输出结果是[7].main(){intm=011,n=11; printf("%d%dn",++m,n++);}(8)以下程序运行后的输出结果是[8].main(){intx,a=1,b=2,c=3,d=4; x=(ax)?x:d; printf("%dn",x);}(9)有以下程序,若运行时从键盘输入:18,11<回车>,则程序的输出结果是[9].main(){inta,b; printf("Entera,b:");scanf("%d,%d",&a,&b); while(a!=b) {while(a>b)a-=b; while(b>a)b-=a; } printf("%3d%3d",a,b);}(10)以下程序的功能是:将输入的正整数按逆序输出.例如:若输入135则输出531,请填空.#includenmain(){intn,s; printf("Enteranumber:");scanf("%d",&n); printf("Output:"); do {s=n%10;printf("%d",s);[10];} while(n!=0); printf("n");}(11)以下程序中,函数fun的功能是计算,主函数中将调用fun函数计算:请填空.#include"math,h"doublefun(doublex){return(x*x-2*x+6);}main(){doublex,y1,y2; printf("Enterx:");scanf("%lf",&x); y1=fun([11]); y2=fun([12]); printf("y1=%lf,y2=%lfn",y1,y2);}(12)下面程序的功能是:将N行N列二维数组中每一行的元素进行排序,第0行从小到大排序,第1行从大到小排序,第2行从小到大排序,第3行从大到小排序,例如:n请填空.#defineN4voidsort(inta[][N]){inti,j,k,t; for(i=0;ia[i][k]) {t=a[i][j]; a[i][j]=a[i][k]; a[i][k]=t; }}voidoutarr(inta[N][N]){ … }main(){inta[N][N]={{2,3,4,1},{8,6,5,7},{11,12,10,9},{15,14,16,13}}; outarr(aa);/*以矩阵的形式输出二维数组*/ sour(aa); outarr(aa);}(13)下列程序中的函数strcpy2()实现字符串两次复制,即将t所指字符串复制两次到s所指内存空间中,合并形成一个新字符串.例如t所指字符串为efgh,调用strcpy2后,s所指字符串为efghefgh.请填空.#include#includenvoidstrcpy2(char*s,char*t){char*p=t; while(*s++=*t++); s=[15]; while([16]=*p++);}main(){charstr1[100]="abcd",str2[]="efgh"; strcpy2(str1,str2); printf("%sn",str1);}(14)下面程序的运行结果是[17].#includeintf(inta[],intn){if(n>1) returna[0]+f(a+1,n-1); else returna[0];}main(){intaa[10]={1,2,3,4,5,6,7,8,9,10},s; s=f(aa+2,4); printf("%dn",s);}(15)下面程序由两个源程序文件:t4.h和t4.c组成,程序编译运行结果是[18].t4.h的源程序为:#defineNn10#definef2(x)(x*N)t4.c的源程序为: #include#defineM 8#definef(x) ((x)*M)#include"t4.h"main(){inti,j; i=f(1+1);j=f2(1+1); printf("%d%dn",i,j);}(16)下面程序的功能是建立一个有3个结点的单循环链表,然后求各个结点数值域data中数据的和,请填空。#include〈stdio.h〉#includestructNODE{intdata; structNODE*next; };main(){structNODE*p,*q,*r; intsum=0; p=(structNODE*)malloc(sizeof(structnNODE)); q=(structNODE*)malloc(sizeof(structNODE)); r=(structNODE*)malloc(sizeof(structNODE)); p->data=100;q->data=200;r->data=300; p->next=q;q->next=r;r->next=p; sum=p->data+p->next->data+r->next->next[19]; printf("%dn",sum);}(17)有以下程序,其功能是:以二进制"写"方式打开文件d1.dat,写入1-100这100个整数后关闭文件,再以二进制"读"方式打开文件d1.dat,将这100个整数读入到另一个数组b中,并打印输出,请填空.#includemain(){FILE*fp; inti,a[100],b[100]; fp=fopen("d1.dat","wb"); for(i=0;i<100;i++)a[i]=i+1; fwrite(a,sizeof(int),100,fp); fclose(fp); fp=fopen("d1.dat",[20]); fread(b,sizeof(int),100,fp); fclose(fp); for(i=0;i<100;i++)printf("%dn",b[i]);}选择题:CACBD CDBAA ADDAD CCBAC DACBC DBCBC ADBAD BBADC CABCD BBBDB填空题:n(1)2 (2)程序调试 (3)元组 (4)栈 (5)线性结构 (6)123.460000 (7)10 11(8)1 (9)1 1 (10)n/=10 (11)x+8 (12)sin(x) (13)j+1 (14)i%2 (15)s-1(16)*s++ (17)18 (18)16 11 (19)->next->data (20)”wb” 答案二:选择题:CACBD CDBAA ADDAD CCBAC DACBC DBCBC ADBAD BBADC CABCD BBBDB填空题:(1)2 (2)软件调试 (3)元组 (4)栈 (5)线性结构 (6)123.460000 (7)10 11(8)1 (9)1 1 (10)n/=10(11)x+8(12)sin(x) (13)j+1 (14)i%2或i%2!=0 (15)s-1 (16)*s++ (17)18 (18)16 11 (19)->next->data (20)”rb”答案三:选择题:CACBD CDBAA ADDAD CCBAC DACBC DBCBC ADBAD BBADC CABCD BBBDB填空题:(1)2 (2)程序调试 (3)元组 (4)栈 (5)线性结构 (6)123.460000 (7)10 11(8)1 (9)1 1 (10)n/=10 (11)x+8 (12)sin(x) (13)j+1 (14)i%2 (15)s-1(16)*s++ (17)18 (18)16 11 (19)->next->data (20)”wb”答案四:选择题:CACBD CDBAA ADDAD CCBAC DACBC DBCBC ADBAD BBADC CABCD BBBDB填空题:(1)3 (2)程序调试 (3)元组 (4)栈 (5)线性结构 (6)123.460000 (7)10 11n(8)1 (9)1 1 (10)n/=10 (11)x+8 (12)sin(x) (13)j+1 (14)i%2 (15)s-1(16)*s++ (17)18 (18)16 11 (19)->next->data (20)”wb”