全国计算机等级考试二级C语言笔试试题及答案.docx

上传人:b****6 文档编号:6088275 上传时间:2023-01-03 格式:DOCX 页数:22 大小:23.37KB
下载 相关 举报
全国计算机等级考试二级C语言笔试试题及答案.docx_第1页
第1页 / 共22页
全国计算机等级考试二级C语言笔试试题及答案.docx_第2页
第2页 / 共22页
全国计算机等级考试二级C语言笔试试题及答案.docx_第3页
第3页 / 共22页
全国计算机等级考试二级C语言笔试试题及答案.docx_第4页
第4页 / 共22页
全国计算机等级考试二级C语言笔试试题及答案.docx_第5页
第5页 / 共22页
点击查看更多>>
下载资源
资源描述

全国计算机等级考试二级C语言笔试试题及答案.docx

《全国计算机等级考试二级C语言笔试试题及答案.docx》由会员分享,可在线阅读,更多相关《全国计算机等级考试二级C语言笔试试题及答案.docx(22页珍藏版)》请在冰豆网上搜索。

全国计算机等级考试二级C语言笔试试题及答案.docx

全国计算机等级考试二级C语言笔试试题及答案

2005年9月全国计算机等级考试二级C语言笔试试题及答案

一、选择题(

(1)—(10)每题2分,(11)—(50)每题1分,共60分)

下列各题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.PDL(过程设计语言)

B.PAD图

C.N-S图

D.DFD图

(7)下列叙述中正确的是

A.软件交付使用后还需要进行维护

B.软件一旦交付使用就不需要再进行维护

C.软件交付使用后其生命周期就结束

D.软件维护是指修复程序中被破坏的指令

(8)数据库设计的根本目标是要解决

A.数据共享问题

B.数据安全问题

C.大量数据存储问题

D.简化数据维护

(9)设有如下关系表:

RST

ABCABCABC

112313112

223223

313

则下列操作中正确的是

A.T=R∩S

B.T=R∪S

C.T=R×S

D.T=R/S

(10)数据库系统的核心是

A.数据模型

B.数据库管理系统

C.数据库

D.数据库管理员

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

A.用户所定义的标识符允许使用关键字

B.用户所定义的标识符应尽量做到“见名知意”

C.用户所定义的标识符必须以字母或下划线开头

D.用户定义的标识符中,大、小写字母代表不同标识

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

A.C语句必须以分号结束

B.复合语句在语法上被看作一条语句

C.空语句出现在任何位置都不会影响程序运行

D.赋值表达式末尾加分号就构成赋值语句

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

A.调用printf函数时,必须要有输出项

B.使用putchar函数时,必须在之前包含头文件stdio.h

C.在C语言中,整数可以以十二进制、八进制或十六进制的形式输出

D.调用getchar函数读入字符时,可以从键盘上输入字符所对应的ASCII码

(14)以下关于函数的叙述中正确的是

A.每个函数都可以被其它函数调用(包括main函数)

B.每个函数都可以被单独编译

C.每个函数都可以单独运行

D.在一个函数内部可以定义另一个函数

(15)若有语句:

char*line[5];,以下叙述中正确的是

A.定义line是一个数组,每个数组元素是一个基类型为char的指针变量

B.定义line是一个指针变量,该变量可以指向一个长度为5的字符型数组

C.定义line是一个指针数组,语句中的*号称为间址运算符

D.定义line是一个指向字符型函数的指针

(16)有以下程序段

typedefstructNODE

{intnum;structNODE*next;

}OLD;

以下叙述中正确的是

A.以上的说明形式非法

B.NODE是一个结构体类型

C.OLD是一个结构体类型

D.OLD是一个结构体变量

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

A.C语言中对二进制文件的访问速度比文本文件快

B.C语言中,随机文件以二进制代码形式存储数据

C.语句FILEfp;定义了一个名为fp的文件指针

D.C语言中的文本文件以ASCII码形式存储数据

(18)当把以下四个表达式用作if语句的控制表达式时,有一个选项与其它三个选项含义不同,这个选项是

A.k%2

B.k%2==1

C.(k%2)!

=0

D.!

k%2==1

(19)以下不能正确计算代数式值的C语言表达式是

A.1/3*sin(1/2)*sin(1/2)

B.sin(0.5)*sin(0.5)/3

C.pow(sin(0.5),2)/3

D.1/3.0*pow(sin(1.0/2),2)

(20)以下能正确定义且赋初值的语句是

A.intn1=n2=10;

B.charc=32;

C.floatf=f+1.1;

D.doublex=12.3E2.5;

(21)以下程序的功能是:

给r输入数据后计算半径为r的圆面积s。

程序在编译时出错。

main()

/*Beginning*/

{intr;floats;

scanf("%d",%26amp;r);

s=*p*r*r;printf("s=%f\n",s);

}

出错的原因是

A.注释语句书写位置错误

B.存放圆半径的变量r不应该定义为整型

C.输出语句中格式描述符非法

D.计算圆面积的赋值语句中使用了非法变量

(22)设有定义:

intk=1,m=2;floatf=7;,则以下选项中错误的表达式是

A.k=k%26gt;=k

B.-k++

C.k%int(f)

D.k%26gt;=f%26gt;=m

(23)设有定义:

inta=2,b=3,c=4;,则以下选项中值为0的表达式是

A.(!

a==1)%26amp;%26amp;(!

b==0)

B.(a

C.a%26amp;%26amp;b

D.a||(b+b)%26amp;%26amp;(c-a)

(24)有以下程序段

intk=0,a=1,b=2,c=3;

k=ac?

c:

k;

执行该程序段后,k的值是

A.3

B.2

C.1

D.0

(25)设变量a、b、c、d和y都已正确定义并赋值。

若有以下if语句

if(a

if(c==d)y=0;

elsey=1;

该语句所表示的含义是

(26)有以下程序段

intn,t=1,s=0;

scanf("%d",%26amp;n);

do{s=s+t;t=t-2;}while(t!

=n);

为使此程序段不陷入死循环,从键盘输入的数据应该是

A.任意正奇数

B.任意负偶数

C.任意正偶数

D.任意负奇数

(27)设变量已正确定义,则以下能正确计算f=n!

的程序段是

A.f=0;

B.f=1;

for(i=1;i%26lt;=n;i++)f*=i;for(i=1;i  

C.f=1;

D.f=1;

for(i=n;i%26gt;1;i++)f*=i;for(i=n;i%26gt;=2;i--)f*=i;

(28)设有定义:

intn1=0,n2,*p=%26amp;n2,*q=%26amp;n1;,以下赋值语句中与n2=n1;语句等价的是

A.*p=*q;

B.p=q;

C.*p=%26amp;n1;

D.p=*q;

(29)若有定义:

intx=0,*p=%26amp;x;,则语句printf("%d\n",*p);的输出结果是

A.随机值

B.0

C.x的地址

D.p的地址

(30)设函数fun的定义形式为

voidfun(charch,floatx){…}

则以下对函数fun的调用语句中,正确的是

A.fun("abc",3.0);

B.t=fun('D',16.5);

C.fun('65',2.8);

D.fun(32,32);

(31)有以下程序

main()

{inta[10]={1,2,3,4,5,6,7,8,9,10},*p=%26a[3],*q=p+2;

printf("%d\n",*p+*q);

}

程序运行后的输出结果是

A.16

B.10

C.8

D.6

(32)有以下程序

main()

{charp[]={'a','b','c'},q[]="abc";

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

};

程序运行后的输出结果是

A.44

B.33

C.34

D.43

(33)有以下程序

#definef(x)(x*x)

main()

{inti1,i2;

i1=f(8)/f(4);i2=f(4+4)/f(2+2);

printf("%d,%d\n",i1,i2);

}

程序运行后的输出结果是

A.64,28

B.4,4

C.4,3

D.64,64

(34)有以下程序

main()

{chara1='M',a2='m';

printf("%c\n",(a1,a2));}

以下叙述中正确的是

A.程序输出大写字母M

B.程序输出小写字母m

C.格式说明符不足,编译出错

D.程序运行时产生出错信息

(35)有以下程序

#include

main()

{charc1='1',c2='2';

c1=getchar();c2=getchar();putchar(c1);putchar(c2);

}

当运行时输入:

a<回车>后,以下叙述正确的是

A.变量c1被赋予字符a,c2被赋予回车符

B.程序将等待用户输入第2个字符

C.变量c1被赋予字符a,c2中仍是原有字符2

D.变量c1被赋予字符a,c2中将无确定值

(36)有以下程序

main()

{intk=5,n=0;

while(k>0)

{switch(k)

{default:

break;

case1:

n+=k;

case2:

case3:

n+=k;

}

k--;

}

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

}

程序运行后的输出结果是

A.0

B.4

C.6

D.7

(37)有以下程序

main()

{inta[]={2,4,6,8,10},y=0,x,*p;

p=%26a[1];

for(x=1;x<3;x++)y+=p[x];

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

}

程序运行后的输出结果是

A.10

B.11

C.14

D.15

(38)有以下程序

voidsort(inta[],intn)

{inti,j,t;

for(i=0;i

for(j=i+1;j

if(a[i]

}

main()

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

sort(aa+2,5);

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

printf("\n");

}

程序运行后的输出结果是

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

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

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

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

(39)有以下程序

voidsum(inta[])

{a[0]=a[-1]+a[1];}

main()

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

sum(%26a[2]);

printf("%d\n",a[2]);

}

程序运行后的输出结果是

A.6

B.7

C.5

D.8

(40)有以下程序

voidswap1(intc0[],intc1[])

{intt;

t=c0[0];c0[0]=c1[0];c1[0]=t;

}

voidswap2(int*c0,int*c1)

{intt;

t=*c0;*c0=*c1;*c1=t;

}

main()

{inta[2]={3,5},b[2]={3,5};

swap1(a,a+1);swap2(%26b[0],%26b[1]);

printf("%d%d%d%d\n",a[0],a[1],b[0],b[1]);

}

程序运行后的输出结果是

A.3553

B.5335

C.3535

D.5353

(41)有以下程序

#include

main()

{charp[]={'a','b','c'},q[10]={'a','b','c'};

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

}

以下叙述中正确的是

A.在给p和q数组置初值时,系统会自动添加字符串结束符,故输出的长度都为3

B.由于p数组中没有字符串结束符,长度不能确定;但q数组中字符串长度为3

C.由于q数组中没有字符串结束符,长度不能确定;但p数组中字符串长度为3

D.由于p和q数组中都没有字符串结束符,故长度都不能确定

(42)有以下程序,其中函数f的功能是将多个字符串按字典顺序排序

#include

voidf(char*p[],intn)

{char*t;inti,j;

for(i=0;i

for(j=i+1;j

if(strcmp(p[i],p[j])>0){t=p[i];p[i]=p[j];p[j]=t;}

}

main()

{char*p[5]={"abc","aabdfg","abbd","dcdbe","cd"};

f(p,5);

printf("%d\n",strlen(p[1]));

}

程序运行后的输出结果是

A.2

B.3

C.6

D.4

(43)有以下程序

#include

voidf(char*s,char*t)

{chark;

k=*s;*s=*t;*t=k;

s++;t--;

if(*s)f(s,t);

}

main()

{charstr[10]="abcdefg",*p;

p=str+strlen(str)/2+1;

f(p,p-2);

printf("%s\n",str);

}

程序运行后的输出结果是

A.abcdefg

B.gfedcba

C.gbcdefa

D.abedcfg

(44)有以下程序

floatf1(floatn)

{returnn*n;}

floatf2(floatn)

{return2*n;}

main()

{float(*p1)(float),(*p2)(float),(*t)(float),y1,y2;

p1=f1;p2=f2;

y1=p2(p1(2.0));

t=p1;p1=p2;p2=t;

y2=p2(p1(2.0));

printf("%3.0f,%3.0f\n",y1,y2);

}

程序运行后的输出结果是

A.8,16

B.8,8

C.16,16

D.4,8

(45)有以下程序

inta=2;

intf(intn)

{staticinta=3;

intt=0;

if(n%2){staticinta=4;t+=a++;}

else{staticinta=5;t+=a++;}

returnt+a++;

}

main()

{ints=a,i;

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

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

}

程序运行后的输出结果是

A.26

B.28

C.29

D.24

(46)有以下程序

#include

structSTU

{intnum;

floatTotalScore;};

voidf(structSTUp)

{structSTUs[2]={{20044,550},{20045,537}};

p.num=s[1].num;p.TotalScore=s[1].TotalScore;

}

main()

{structSTUs[2]={{20041,703},{20042,580}};

f(s[0]);

printf("%d%3.0f\n",s[0].num,s[0].TotalScore);

}

程序运行后的输出结果是

A.20045537

B.20044550

C.20042580

D.20041703

(47)有以下程序

#include

structSTU

{charname[10];

intnum;};

voidf(char*name,intnum)

{structSTUs[2]={{"SunDan",20044},{"Penghua",20045}};

num=s[0].num;

strcpy(name,s[0].name);

}

main()

{structSTUs[2]={{"YangSan",20041},{"LiSiGuo",20042}},*p;

p=%26s[1];f(p->name,p->num);

printf("%s%d\n",p->name,p->num);

}

程序运行后的输出结果是

A.SunDan20042

B.SunDan20044

C.LiSiGuo20042

D.YangSan20041

(48)有以下程序

structSTU

{charname[10];intnum;floatTotalScore;};

voidf(structSTU*p)

{structSTUs[2]={{"SunDan",20044,550},{"Penghua",20045,537}},*q=s;

++p;++q;*p=*q;

}

main()

{structSTUs[3]={{"YangSan",20041,703},{"LiSiGuo",20042,580}};

f(s);

printf("%s%d%3.0f\n",s[1].name,s[1].num,s[1].TotalScore);

}

程序运行后的输出结果是

A.SunDan20044550

B.Penghua20045537

C.LiSiGuo20042580

D.SunDan20041703

(49)以下程序的功能是进行位运算

main()

{unsignedchara,b;

a=7^3;b=~4%263;

printf("%d%d\n",a,b);

}

程序运行后的输出结果是

A.43

B.73

C.70

D.40

(50)有以下程序

#include

main()

{FILE*fp;inti,k,n;

fp=fopen("data.dat","w+");

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

{fprintf(fp,"%d",i);

if(i%3==0)fprintf(fp,"\n");

}

rewind(fp);

fscanf(fp,"%d%d",%26k,%26n);printf("%d%d\n",k,n);

fclose(fp);

}

程序运

行后的输出结果是

A.00

B.12345

C.14

D.12

二、填空题(每空2分,共40分)

请将每一个空的正确答案写在答题卡【1】至【20】序号的横线上,答在试卷上不得分。

(1)数据管理技术发展过程经过人工管理、文件系统和数据库系统三个阶段,其中数据独立性最高的阶段是【1】。

(2)算法复杂度主要包括时间复杂度和【2】复杂度。

(3)在进行模块测试时,要为每个被测试的模块另外设计两类模块:

驱动模块和承接模块(桩模块)。

其中【3】的作用是将测试数据传送给被测试的模块,并显示被测试模块所产生的结果。

(4)一棵二叉树第六层(根结点为第一层)的结点数最多为【4】个。

(5)数据结构分为逻辑结构和存储结构,循环队列属于【5】结构。

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

main()

{intx=0210;printf("%X\n",x);

}

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

main()

{inta=1,b=2,c=3;

if(c=a)printf("%d\n",c);

elseprintf("%d\n",b);

}

(8)已有定义:

double*p;,请写出完整的语句,利用malloc函数使p指向一个双精度型的动态存储单元【8】。

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

main()

{charc;intn=100;

floatf=10;doublex;

x=f*=n/=(c=50);

printf("%d%f\n",n,x);

}

(10)以下程序的功能是计算:

s=1+12+123+1234+12345。

请填空。

main()

{intt=0,s=

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

当前位置:首页 > 自然科学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1