二级C语言真题及答案.docx

上传人:b****6 文档编号:7407931 上传时间:2023-05-11 格式:DOCX 页数:21 大小:40.78KB
下载 相关 举报
二级C语言真题及答案.docx_第1页
第1页 / 共21页
二级C语言真题及答案.docx_第2页
第2页 / 共21页
二级C语言真题及答案.docx_第3页
第3页 / 共21页
二级C语言真题及答案.docx_第4页
第4页 / 共21页
二级C语言真题及答案.docx_第5页
第5页 / 共21页
二级C语言真题及答案.docx_第6页
第6页 / 共21页
二级C语言真题及答案.docx_第7页
第7页 / 共21页
二级C语言真题及答案.docx_第8页
第8页 / 共21页
二级C语言真题及答案.docx_第9页
第9页 / 共21页
二级C语言真题及答案.docx_第10页
第10页 / 共21页
二级C语言真题及答案.docx_第11页
第11页 / 共21页
二级C语言真题及答案.docx_第12页
第12页 / 共21页
二级C语言真题及答案.docx_第13页
第13页 / 共21页
二级C语言真题及答案.docx_第14页
第14页 / 共21页
二级C语言真题及答案.docx_第15页
第15页 / 共21页
二级C语言真题及答案.docx_第16页
第16页 / 共21页
二级C语言真题及答案.docx_第17页
第17页 / 共21页
二级C语言真题及答案.docx_第18页
第18页 / 共21页
二级C语言真题及答案.docx_第19页
第19页 / 共21页
二级C语言真题及答案.docx_第20页
第20页 / 共21页
亲,该文档总共21页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

二级C语言真题及答案.docx

《二级C语言真题及答案.docx》由会员分享,可在线阅读,更多相关《二级C语言真题及答案.docx(21页珍藏版)》请在冰点文库上搜索。

二级C语言真题及答案.docx

二级C语言真题及答案

2007年4月全国计算机等级考试笔试试卷

一、选择题

下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的。

(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)DYBEAFCZXB)YDEBFZXCAC)ABDYECFXZD)ABCDEFXYZ

(7)某二叉树中有n个度为2的结点,则该二叉树中的叶子结点数为

A)n+lB)n-1C)2nD)n/2

(8)在下列关系运算中,不改变关系表中的属性个数但能减少元组个数的是

A)并B)交C)投影D)笛卡儿乘积

(9)在E-R图中,用来表示实体之间联系的图形是

A)矩形B)椭圆形C)菱形D)平行四边形

(10)下列叙述中错误的是

A)在数据库系统中,数据的物理结构必须与逻辑结构一致B)数据库技术的根本目标是要解决数据的共享问题

C)数据库设计是指在已有数据库管理系统的基础上建立数据库D)数据库系统需要操作系统的支持

(11)算法中,对需要执行的每一步操作,必须给出清楚、严格的规定。

这属于算法的

A)正当性B)可行性C)确定性D)有穷性

(12)以下叙述中错误的是

A)计算机不能直接执行用C语言编写的源程B)C程序经C编译程序编译后,生成后缀为.obj的文件是一个二进制文件C)后缀为.obj的文件,经连接程序生成后缀为.exe的文件是一个二进制文字D)后缀为.obj和.exe的二进制文件都可以直接运行

(13)按照C语言规定的用户标识符命名规则,不能出现在标识符中的是

A)大写字母B)连接符C)数字字符D)下划线

(14)以下叙述中错误的是

A)C语言是一种结构化程序设计语言B)结构化程序由顺序、分支、循环三种基本结构组C)使用三种基本结构构成的程序只能解决简单问题D)结构化程序设计提倡模块化的设计方法

(15)对于一个正常运行的C程序,以下叙述中正确的是

A)程序的执行总是从main函数开始,在main函数结束B)程序的执行总是从程序的第一个函数开始,在main函数结束C)程序的执行总是从main函数开始,在程序的最后一个函数中结束D)程序的执行总是从程序中的第一个函数开始,在程序的最后一个函数中结束

(16)设变量均已正确定义,若要通过scanf("%d%c%d%c",&a1,&c1,&a2,&c2);语句为变量a1和a2赋数值10和20,为变量c1和c2赋字符X和Y。

以下所示的输入形式中正确的是(注:

口代表空格字符)

A)10口X口20口Y<回车>B)10口X20口Y<回车>

C)10口X<回车>20口Y<回车>D)10X<回车>20Y<回车>

(17)若有代数式

(其中e仅代表自然对数的底数,不是变量),则以下能够正确表示该代数式的C语言表达式是

A)sqrt(abs(n^x+e^X))B)sqrt(fabs(pow(n,x)+pow(x,e)))C)sqrt(fabs(pow(n,x)+exp(X)))D)sqrt(fabs(pow(x,n)+exp(x)))

(18)设有定义:

intk=0;,以下选项的四个表达式中与其他三个表达式的值不相同的是

A)k++B)k+=1C)++kD)k+1

(19)有以下程序,其中%u表示按无符号整数输出

main()

{unsignedintx=0xFFFF;/*x的初值为+六进制数*/

printf("%u\n",x);

}

程序运行后的输出结果是

A)-1B)65535C)32767D)0xFFFF

(20)设变量x和y均已正确定义并赋值。

以下if语句中,在编译时将产生错误信息的是

A)if(x++);B)if(x>y&&y!

=0);C)if(x>0)x-elsey++;D)if(y<0){;}elsex++;

(21)以下选项中,当x为大于1的奇数时,值为0的表达式是

A)x%2==1B)x/2C)x%2!

=0D)x%2==0

(22)以下叙述中正确的是

A)break语句只能用于switch语句体中B)continue语句的作用是:

使程序的执行流程跳出包含它的所有循环

C)break语句只能用在循环体内和switch语句体内D)在循环体内使用break语句和continue语句的作用相同

(23)有以下程序

main()

{intk=5,n=0;

do

{switch(k){case1:

case3:

n+=1;k--;break;

default:

n=0;k--;

case2:

case4:

n+=2;k--;break;}

printf("%d",n);}while(k>0&&n<5);}

程序运行后的输出结果是

A)235B)0235C)02356D)2356

(24)有以下程序

main()

{inti,j;

for(i=1;i<4;i++)

{for(j=i;j<4;j++)printf("%d*%d=%d",i,j,i*j);

printf("\n");

}

}

程序运行后的输出结果是

A)1*1=11*2=21*3=3

2*1=22*2=4

3*1=3

B)1*1=11*2=21*3=3

2*2=42*3=6

3*3=9

C)1*1=1

1*2=22*2=4

1*3=32*3=63*3=9

D)1*1=1

2*1=22*2=4

3*1=33*2=63*3=9

(25)以下合法的字符型常量是

A)'\x13'B)'\081'C)'65'D)"\n"

(26)在C语言中,函数返回值的类型最终取决于

A)函数定义时在函数首部所说明的函数类型B)return语句中表达式值的类型

C)调用函数时主调函数所传递的实参类型D)函数定义时形参的类型

(27)已知大写字母A的ASCII码是65,小写字母a的ASCII码是97。

以下不能将变量c中的大写字母转换为对应小写字母的语句是

A)c=(c-'A')%26+'a'B)c=c+32C)c=c-'A'+'a'D)c=('A'+c)%26-'a'

(28)有以下函数

intfun(char*s)

{char*t=s;

while(*t++);

return(t-s);

}

该函数的功能是

A)比较两个字符串的大小B)计算s所指字符串占用内存字节的个数C)计算s所指字符串的长度D)将s所指字符串复制到字符串t中

(29)设已有定义:

floatx;,则以下对指针变量p进行定义且赋初值的语句中正确的是

A)float*p=1024;B)int*p=(float)x;C)floatp=&x;D)float*p=&x;

(30)有以下程序

#include<stdio.h>

main()

{intn,*p=NULL;

*p=&n;

printf("Inputn:

");scanf("%d",&p);printf("outputn:

");printf("%d\n",p);

}

该程序试图通过指针p为变量n读入数据并输出,但程序有多处错误,以下语句正确的是

A)intn,*p=NULL;B)*p=&n;C)scanf("%d",&p)D)printf("%d\n",p);

(31)以下程序中函数f的功能是:

当flag为1时,进行由小到大排序;当flag为0时,进行由大到小排序。

voidf(intb[],intn,intflag)

{inti,j,t;

for(i=0;i<n-1;i++)

for(j=i+1;j<n;j++)

if(flag?

b[i]>b[j]:

b[i]<b[j]){t=b[i];b[i]=b[j];b[j]=t;}

}main()

{inta[10]={5,4,3,2,1,6,7,8,9,10},i;

f(&a[2],5,0);f(a,5,1);

for(i=0;i<10;i++)printf("%d,",a[i]);

}

程序运行后的输出结果是

A)1,2,3,4,5,6,7,8,9,10,B)3,4,5,6,7,2,1,8,9,10,

C)5,4,3,2,1,6,7,8,9,10,D)10,9,8,7,6,5,4,3,2,1,

(32)有以下程序

voidf(intb[])

{inti;

for(i=2;i<6;i++)b[i]*=2;}

main(){inta[10]={1,2,3,4,5,6,7,8,9,10),i;

f(a);for(i=0;i<10,i++)printf("%d,",a[i]);}

程序运行后的输出结果是

A)1,2,3,4,5,6,7,8,9,10,B)1,2,6,8,10,12,7,8,9,10,

C)1,2,3,4,10,12,14,16,9,10,D)1,2,6,8,10,12,14,16,9,10,

(33)有以下程序

typedefstruct{intb,p;}A;

voidf(Ac)/*注意:

c是结构变量名*/

{intj;

c.b+=1;c.p+=2;}

main(){inti;

Aa={1,2};f(a);printf("%d,%d\n",a.b,a.p);}

程序运行后的输出结果是

A)2,3B)2,4C)1,4D)1,2

(34)有以下程序

main()

{inta[4][4]={{1,4,3,2},{8,6,5,7},{3,7,2,5},{4,8,6,1}},i,j,k,t;

for(i=0;<4:

i++)

for(j=0;j<3;j++)

for(k=j+1;k<4;k++)

if(a[j][i]>a[k][i]{t=a[j][i];a[j][i]=a[k][i]=a[k][i]=t;}/*按列排序*/

for(i=0;i<4;i++)printf("%d,",a[i][i]);}

程序运行后的输出结果是

A)1,6,5,7,B)8,7,3,1,C)4,7,5,2,D)1,6,2,1,

(35)有以下程序

main()

{inta[4][4]={{1,4,3,2},{8,6,5,7},{3,7,2,5},{4,8,6,1}},i,k,t;

for(i=0;i<3;i++)

for(k=i+1;k<4;k++)if(a[i][i]<a[k][k]){t=a[i][i];a[i][i]=a[k][k];a[k][k]=t;}

for(i=0;i<4;i++)printf("%d,",a[0][i]);

}

程序运行后的输出结果是

A)6,2,1,1,B)6,4,3,2,C)1,1,2,6,D)2,3,4,6,

(36)有以下程序

voidf(int*q){inti=0;

for(;i<5;i++)(*q)++;}

main(){inta[5]={1,2,3,4,5},i;

f(a);for(i=0;i<5;i++)printf("%d,",a[i]);}

程序运行后的输出结果是

A)2,2,3,4,5,B)6,2,3,4,5,C)1,2,3,4,5,D)2,3,4,5,6,

(37)有以下程序

#include<string.h>

main(){charp[20]={'a','b','c','d'},q[]="abc",r[]="abcde";

strcpy(p+strlen(q),r);strcat(p,q);printf("%d%d\n",sizeof(p),strlen(p));}

程序运行后的输出结果是

A)209B)99C)2011D)1111

(38)有以下程序

#include<string.h>

main(){charp[20]={'a','b','c','d'},q[]="abc",r[]="abcde";

strcat(p,r);strcpy(p+strlen(q),q);printf("%d\n",strlen(p));}

程序运行后的输出结果是

A)9B)6C)11D)7

(39)有以下程序

#include<string.h>

voidf(charp[][10],intn)/*字符串从小到大排序*/

{chart[10];inti,j;

for(i=0;i<n-1;i++)

for(j=i+1;j<n;j++)if(strcmp(p[i],p[j])>0){strcpy(t,p[i]);strcpy(p[i],p[j]);strcpy(p[j],t);}}

main(){charp[5][10]={"abc","aabdfg:

,"abbd","dcdbe","cd"};

f(p,5);printf("%d\n",strlen(p[0]));}

程序运行后的输出结果是

A)2B)4C)6D)3

(40)有以下程序

voidf(intn,int*r){intr1=0;

if(n%3==0)r1=n/3;

elseif(n%5==0)r1=n/5;

elsef(--n,&r1);

*r=r1;}

main(){intm=7,r;

f(m,&r);printf("%d",r);}

程序运行后的输出结果是

A)2B)1C)3D)0

(41)有以下程序

main(intargc,char*argv[]){intn=0,i;

for(i=1;i<argc;i++)n=n*10+*argv[i]'0';printf("%d\n",n);}

编译连接后生成可执行文件tt.exe。

若运行时输入以下命令行

tt12345678

程序运行后的输出结果是

A)12B)12345C)12345678D)136

(42)有以下程序

inta=4;

intf(intn){intt=0;staticinta=5;

if(n%2){inta=6;t+=a++;}

else{inta=7;t+=a++;}

returnt+a++;}

main(){ints=a,i=0;

for(;i<2;i++)s+=f(i);printf("%d\n",s);}

程序运行后的输出结果是

A)24B)28C)32D)36

(43)有一个名为init.txt的文件,内容如下:

#defineHDY(A,B)A/B

#definePRINT(Y)printf("y=%d\n",Y)

有以下程序

#include"init.txt"

main(){inta=1,b=2,c=3,d=4,k;

k=HDY(a+c,b+d);PRINT(k);}

下面针对该程序的叙述正确的是

A)编译出错B)运行出错C)运行结果为y=0D)运行结果为y=6

(44)有以下程序

main(){charch[]="uvwxyz",*pc;

pc=ch;printf("%c\n",*(pc+5));}

程序运行后的输出结果是

A)zB)0C)元素ch[5]的地址D)字符y的地址

(45)有以下程序

structS{intn;inta[20];};

voidf(structS*p){inti,j,t;

for(i=0;i<p->n-1;i++)

for(j=i+1;j<p->n;j++)

if(p->a[i]>p->a[j]){t=p->a[i];p->a[i]=p->a[j];p->a[j]=t;}}

main(){inti;structSs={10,{2,3,l,6,8,7,5,4,10,9}};

f(&s);for(i=0;i<s.n;i++)printf("%d,",s.a[i]);

}

程序运行后的输出结果是

A)1,2,3,4,5,6,7,8,9,10,B)10,9,8,7,6,5,4,3,2,1,

C)2,3,1,6,8,7,5,4,10,9,D)10,9,8,7,6,1,2,3,4,5,

(46)有以下程序

structS{intn;inta[20];};

voidf(int*a,intn){inti;

for(i=0;i<n-1;i++)a[i]+=i;}

main(){inti;structSs={10,{2,3,1,6,8,7,5,4,10,9}};

f(s.a,s.n);for(i=0;i<s.n;i++)printf("%d,",s.a[i]);}

程序运行后的输出结果是

A)2,4,3,9,12,12,11,11,18,9,B)3,4,2,7,9,8,6,5,11,10,

C)2,3,1,6,8,7,5,4,10,9,D)1,2,3,6,8,7,5,4,10,9,

(47)有以下程序段

typedefstructnode{intdata;structnode*next;}*NODE;NODEp;

以下叙述中正确的是

A)p是指向structnode结构变量的指针的指针B)NODEp;语句出错C)p是指向structnode结构变量的指针D)p是structnode结构变量

(48)有以下程序

main()

{unsignedchara=2,b=4,c=5,d;

d=a|b;d&=c;printf("%d\n",d);}程序运行后的输出结果是

A)3B)4C)5D)6

(49)有以下程序

#include<stdio.h>

main(){FILE*fp;intk,n,a[6]={1,2,3,4,5,6};

fp=fopen("d2.dat","w");fprintf(fp,"%d%d%d\n",a[0],a[1],a[2]);fprintf(fp,"%d%d%d\n",a[3],a[4],a[5]);

fclose(fp);fp=fopen("d2.daf","r");

fscanf(fp,"%d%d",&k,&n);printf("%d%d\n",k,n);fclose(fp);}

程序运行后的输出结果是

A)12B)14C)1234D)123456

(50)有以下程序

#include<stdio.h>

main(){FILE*fp;inti,a[6]={1,2,3,4,5,6};

fp=fopen("d3.dat","w+b");fwrite(a.sizeof(int),6,fp);fseek(fp,sizeof(int)*3,SEEK_SET):

/*该语句使读文件的位置指针从文件头向后移动3个int型数据*/fread(a,sizeof(int),3,fp);fclose(fp);

for(i=0;i<6;i++)printf("%d,",a[i]);}

程序运行后的输出结果是

A)4,5,6,4,5,6,B)1,2,3,4,5,6,C)4,5,6,1,2,3,D)6,5,4,3,2,1,

二、填空题

请将每一个空的正确答案写在【1】至【20】序号的横线上。

(1)在深度为7的满二叉树中,度为2的结点个数为【1】。

(2)软件测试分为白箱(盒)测试和黑箱(盒)测试。

等价类划分法属于【2】测试。

(3)在数据库系统中,实现各种数据管理功能的核心软件称为【3】。

(4)软件生命周期可分为多个阶段,一般分为定义阶段、开发阶段和维护阶段。

编码和测试属于【4】阶段。

(5)在结构化分析使用的数据流图(DFD)中,利用【5】对其中的图形元素进行确切解释。

(6)执行以下程序后的输出结果是【6】。

main()

{inta=10;

a=(3*5,a+4);printf("a=%d\n",a);

}

(7)当执行以下程序时,输入1234567890<回车>,则其中while循环体将执行【7】次。

#include<stdio.h>

main()

{charch;

while((ch=getchar())=='0')prinft("#");

}

(8)以下程序的运行结果是【8】。

intk=0;

voidfun(intm)

{m+=k;k+=m;printf("m=%dk=%d",m,k++);}

main()

{inti=4;

fun(i++);printf("i=%dk=%d\n",i,k);

}

(9)以下程序的运行结果是【9】。

main()

{inta=2,b=7,c=5;

switch(a>0){case1:

switch(b<0){case1:

printf("@");break;

case2:

printf("!

");break;}

case0:

switch(c==5){case0:

printf("*");break;

case1:

printf("#");break;

ca

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 幼儿教育 > 幼儿读物

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2