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

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

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

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

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

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

2010年9月全国计算机等级考试二级笔试试卷

C语言程序设计(附答案)

(考试时间90分钟,满分100分)

一、选择题(

(1)—(10)、(21)—(40)每题2分,(11)—(20)每题1分,共70分)

下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的,请将正确的选项填涂在答题卡相应位置上,答在试卷上不得分。

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

A)线性表的链式存储结构与顺序存储结构所需要的存储空间是相同的

B)线性表的链式存储结构所需要的存储空间一般要多于顺序存储结构

C)线性表的链式存储结构所需要的存储空间一般要少于顺序存储结构

D)上述三种说法都不对

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

A)在栈中,栈中元素随栈底指针与栈顶指针的变化而动态变化B)在栈中,栈顶指针不变,栈中元素随栈底指针的变化而动态变化C)在栈中,栈底指针不变,栈中元素随栈顶指针的变化而动态变化D)上述三种说法都不对

(3)软件测试的目的是

A)评估软件可靠性

B)发现并改正程序中的错误

C)改正程序中的错误

D)发现程序中的错误

(4)下面描述中,不属于软件危机表现的是

A)软件过程不规范B)软件开发生产率低C)软件质量难以控制C)软件成本不断提高

(5)软件生命周期是指

A)软件产品从提出、实现、使用维护到停止使用退役的过程

B)软件从需求分析、设计、实现到测试完成的过程

C)软件的开发过程

D)软件的运行维护过程

(6)面向对象方法中,继承是指

A)一组对象所具有的相似性质

B)一个对象具有另一个对象的性质

C)各对象之间的共同性质

D)类之间共享属性和操作的机制

(7)层次型、网状型和关系型数据库划分原则是

A)记录长度B)文件的大小B)联系的复杂程度D)数据之间的联系方式

(8)一个工作人员可以使用多台计算机,而一台计算机可被多个人使用,则实体工作人员与实体计算机之间的联系是

A)一对一B)一对多C)多对多D)多对一

(9)数据库设计中反映用户对数据要求的模式是

A)内模式B)概念模式C)外模式D)设计模式

(10)有三个关系R、S和T如下:

A

B

C

D

c

3

1

RST

A

B

C

a

1

2

b

2

1

c

3

1

A

D

c

4

则由关系R和S得到关系T的操作是

A)自然连接B)交C)投影D)并

(11)以下关于结构化程序设计的叙述中正确的是

A)一个结构化程序必须同时由顺序、分支、循环三种结构组成

B)结构化程序使用goto语句会很便捷

C)在C语言中,程序的模块化是利用函数实现的

D)由三种基本结构构成的程序只能解决小规模的问题

(12)以下关于简单程序设计的步骤和顺序的说法中正确的是

A)确定算法后,整理并写出文档,最后进行编码和上机调试

B)首先确定数据结构,然后确定算法,再编码,并上机调试,最后整理文档

C)先编码和上机调试,在编码过程中确定算法和数据结构,最后整理文档

D)先写好文档,再根据文档进行编码和上机调试,最后确定算法和数据结构

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

A)C程序在运行过程中所有计算都以二进制方式进行

B)C程序在运行过程中所有计算都以十进制方式进行

C)所有C程序都需要编译链接无误后才能进行

D)C程序中整型变量只能存放整数,实型变量只能存放浮点数

(14)有以下定义:

inta;

longb;

doublex,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”

(16)表达式a+=a-=a=9的值是

A)9B)-9C)18D)0

(17)若变量已正确定义,在if(W)printf(“%d\n”,k);中,以下不可替代W的是

A)a<>b+cB)ch=getchar()C)a==b+cD)a++

(18)有以下程序

#include

main()

{inta=1,b=0;

if(!

a)b++;

elseif(a==0)

if(a)b+=2;

elseb+=3;

printf(“%d\n”,b);

}

程序运行后的输出结果是

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

(19)若有定义语句

inta,b;

doublex;

则下列选项中没有错误的是

A)switch(x%2)

{case0:

a++;break;

case1:

b++;break;

default:

a++;b++;}

B)switch((int)x/2.0)

{case0:

a++;break;

case1:

b++;break;

default:

a++;b++;}

C)switch((int)x%2)

{case0:

a++;break;

case1:

b++;break;

default:

a++;b++;}

D)switch((int)(x)%2)

{case0.0:

a++;break;

case1.0:

b++;break;

default:

a++;b++;}

(20)有以下程序

#include

main()

{inta=1,b=2;

while(a<6){b+=a;a+=2;b%=10;}

printf(“%d,%d\n”,a,b);

}

程序运行后的输出结果是

A)5,11B)7,1C)7,11D)6,1

(21)有以下程序

#include

main()

{inty=10;

while(y--);

printf(“y=%d\n”,y);

}

程序执行后的输出结果是

A)y=0B)y=-1C)y=1D)while构成无限循环

(22)有以下程序

#include

main()

{chars[]=”rstuv”;

printf(“%c\n”,*s+2);

}

程序运行后的输出结果是

A)tuvB)字符t的ASCII值C)tD)出错

(23)有以下程序

#include

#include

main()

{charx[]=”STRING”;

x[0]=0;x[1]=‟\0‟;x[2]=‟0‟;

printf(“%d%d\n”,sizeof(x),strlen(x));

}

程序运行后的输出结果是

A)61B)70C)63D)71

(24)有以下程序

#include

intf(intx);

main()

{intn=1,m;

m=f(f(f(n)));

printf(“%d\n”,m);

}

intf(intx)

{returnx*2;}

程序运行后的输出结果是

A)1B)2C)4D)8

(25)以下程序段完全正确的是

A)int*p;scanf(“%d”,&p);

B)int*p;scanf(“%d”,p);

C)intk,*p=&k;scanf(“%d”,p);

D)intk,*p;*p=&k;scanf(“%d”,p);

(26)有定义语句:

int*p[4];

以下选项中与此语句等价的是

A)intp[4];B)int**p;C)int*(p[4]);D)int(*p)[4];

(27)下列定义数组的语句中,正确的是

A)intN=10;B)#defineN10intx[N];intx[N];C)intx[0..10];D)intx[];

(28)若要定义一个具有5个元素的整型数组,以下错误的定义语句是

A)inta[5]={0};B)intb[]={0,0,0,0,0};C)intc[2+3];D)inti=5,d[i];

(29)有以下程序

#include

voidf(int*p);

main()

{inta[5]={1,2,3,4,5},*r=a;

f(r);

printf(“%d\n”,*r);}

voidf(int*p)

{p=p+3;

printf(“%d,”,*p);

}

程序运行后的输出结果是

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

(30)有以下程序(函数fun只对下标为偶数的元素进行操作)

#include

voidfun(int*a,intn)

{inti,j,k,t;

for(i=0;i

{k=i;

for(j=i;ja[k])k=j;

t=a[i];a[i]=a[k];a[k]=t;}

}

main()

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

fun(aa,7);

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

printf(“%d,”,aa[i]);

printf(“\n”);

}

程序运行后输出结果是

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

(31)下列选项中,能够满足“若字符串s1等于字符串s2,则执行ST”要求的是

A)if(strcmp(s2,s1)==0)ST;

B)if(s1==s2)ST;

C)if(strcpy(s1,s2)==1)ST;

D)if(s1-s2==0)ST;

(32)以下不能将s所指字符串正确复制到t所指存储空间的是

A)while(*t=*s){t++,s++;}

B)for(i=0;t[i]=s[i];i++);

C)do{*t++=*s++;}while(*s);

D)for(i=0,j=0;t[i++]=s[j++];);

(33)有以下程序(strcat函数用以连接两个字符串)

#include

#include

main()

{chara[20]=”ABCD\0EFG\0”,b[]=”IJK”;

strcat(a,b);

printf(“%s\n”,a);

}

程序运行后的输出结果是

A)ABCDE\OFG\OIJKB)ABCDIJKC)IJKD)EFGIJK

(34)有以下程序,程序中库函数islower(ch)用以判断ch中的字母是否为小写字母

#include

#include

voidfun(char*p)

{inti=0;

while(p[i])

{if(p[i]==‟„&&islower(p[i-1]))p[i-1]=p[i-1]-‟a‟+‟A‟;

i++;

}

}

main()

{chars1[100]=”abcdEFG!

”;

fun(s1);

printf(“%s\n”,s1);

}

程序运行后的结果是

A)abcdEFG!

B)AbCdEFg!

C)aBcDEFG!

D)abcdEFg!

(35)有以下程序

#include

voidfun(intx)

{if(x/2>1)

fun(x/2);

printf(“%d”,x);

}

main()

{fun(7);

printf(“\n”);

}

程序运行后的输出结果是

A)137B)731C)73D)37

(36)有以下程序

#include

intfun()

{staticintx=1;

x+=1;

returnx;

}

main()

{inti,s=1;

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

s+=fun();

printf(“%d\n”,s);

}

程序运行后的输出结果是

A)11B)21C)6D)120

(37)有以下程序`

#include

#include

main()

{int*a,*b,*c;

a=b=c=(int*)malloc(sizeof(int));

*a=1;*b=2;*c=3;

a=b;

printf(“%d,%d,%d\n”,*a,*b,*c);

}

程序运行后的输出结果是

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

(38)有以下程序

#include

main()

{ints,t,A=10;

doubleB=6;

s=sizeof(A);

t=sizeof(B);

printf(“%d,%d\n”,s,t);

}

在VC6平台上编绎运行,程序运行后输出结果是

A)2,4B)1,4C)4,8D)10,6

(39)若有以下语句

typedefstructS

{intg;charh;}T;

以下叙述中正确的是

A)可用S定义结构体变量B)可用T定义结构体变量C)S是struct类型的变量D)T是structS类型的变量

(40)有以下程序

#include

main()

{shortc=124;c=c;

printf(“%d\n”,c);

}

若要使程序的运行结果为248,应在下划线处填入的是

A)>>2B)|248C)&0248D)<<1

二、填空题(每空2分,共30分)请将每空的正确答案写在答题卡【1】至【15】序号的横线上,答在试卷上不得分。

(1)一个栈的初始状态为空。

首先将元素5,4,3,2,1依次入栈,然后退栈一次,再将元素A,B,C,D依次入栈,之后将所有元素全部退栈,则所有元素退栈(包括中间退栈的元素)的顺序为【1】。

(2)在长度为n的线性表中,寻找最大项至少需要比较【2】次。

(3)一棵二叉树有10个度为1的结点,7个度为2的结点,则该二叉树共有【3】个结点。

(4)仅由顺序、选择(分支)和重复(循环)结构构成的程序是【4】程序。

(5)数据库设计的四个阶段是:

需求分析,概念设计,逻辑设计和【5】。

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

#includemain()

{inta=200,b=010;

printf(“%d%d\n”,a,b);

}

(7)有以下程序

#include

main()

{intx,y;

scanf(“%2d%ld”,&x,&y);

printf(“%d\n”,x+y);

}

程序运行时输入:

1234567,程序的运行结果是【7】。

(8)在C语言中,当表达式值为0时表示逻辑值“假”,当表达式为【8】时表示逻辑值“真”。

(9)有以下程序

#include

main()

{inti,n[]={0,0,0,0,0};

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

{n[i]=n[i-1]*3+1;

printf(“%d”,n[i]);

}

}

程序运行后输出结果是【9】。

(10)以下fun函数的功能是:

找出具有N个元素的一维数组中的最小值,并作为函数值返回,请填空。

(设N已定义)

intfun(intx[N])

{inti,k=0;

for(i=0;i

if(x[i]

returnx[k];

}

(11)有以下程序

#include

int*f(int*p,int*q);

main()

{intm=1,n=2,*r=&m;

r=f(r,&n);printf(“%d\n”,*r);

}

int*f(int*p,int*q)

{return(*p>*q)?

p:

q;}

程序运行后的输出结果是【11】。

(12)以下fun函数的功能是在N行M列的整型二维数组中,选出一个最大值作为函数值返回,请填空。

(设M,N已定义)

intfun(inta[N][M])

{inti,j,row=0,col=0;

for(i=0;ia[row][col])

{row=i;col=j;

}

return(【12】);

}

(13)有以下程序

#include

main()

{intn[2],i,j;

for(i=0;i<2;i++)n[i]=0;

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

for(j=0;j<2;j++)n[j]=n[i]+1;

printf(“%d\n”,n[1]);

}

程序运行后的输出结果是【13】。

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

借助指针变量找出数组元素中最大值所在的位置并输出该最大值。

请在输出语句中填写代表最大值的输出项。

#include

main()

{inta[10],*p,*s;

for(p=a;p-a<10;p++)

scanf(“%d”,p);

for(p=a,s=a;p-a<10;p++)

if(*p>*s)s=p;

printf(“max=%d\n”,【14】);

}

(15)以下程序打开新文件f.txt,并调用字符输出函数将a数组中的字符写入其中,请填空。

#include

main()

{【15】*fp;

chara[5]={„1‟,‟2‟,‟3‟,‟4‟,‟5‟},i;

fp=fopen{“f,txt”,”w”};

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

fputc{a[i],fp};f

close(fp);

}

2010年9月二级C语言笔试真题参考答案

一、选择题1-5BCDAA6-10DDCCA11-15CBBAD16-20DAACB21-25BCBDC26-30CBDDA31-35ACBCD36-40BACBD二、填空题1.1DCBA23452.13.254.结构化5.物理设计6.20087.158.非09.14134010.i11.212.a[row][col]13.314.*s15.FILE

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

当前位置:首页 > 高等教育 > 历史学

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

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