您好,欢迎来到尚佳旅游分享网。
搜索
您的当前位置:首页全国计算机等级考试二级C语言试题及答案(201009)

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

来源:尚佳旅游分享网
文档供参考,可复制、编制,期待您的好评与关注!

2010年9月全国计算机二级C语言笔试试题:文字版

一、选择题(每小题2分,共70分)

下列各题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)一组对象所具有的相似性质 B)一个对象具有另一个对象的性质

1 / 14

文档供参考,可复制、编制,期待您的好评与关注!

C)各对象之间的共同性质 D)类之间共享属性和操作的机制

(7)层次型、网状型和关系型数据库划分原则是 A)记录长度 B)文件的大小 C)了解的复杂程度 D)数据之间的了解方式

(8)一个工作人员可以使用多台计算机,而一台计算机可被多个人使用,则实体工作人员、与实体计算机之间的了解是 A)一对一 B)一对多 C)多对多 D)多对一

(9)数据库设计中反映用户对数据要求的模式是 A)内模式 B)概念模式 C)外模式 D)设计模式

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

则由关系R和S得到关系T的操作是 A)自然连接 B)交 C)投影 D)并

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

A)一个结构化程序必须同时由顺序、分支、循环三种结构组成 B)结构化程序使用goto语句会很便捷

C)在C语言中,程序的模块化是利用函数实现的 D)由三种基本结构构成的程序只能解决小规模的问题

(12)以下关于简单程序设计的步骤和顺序的说法中正确的是 A)确定算法后,整理并写出文档,最后进行编码和上机调试

2 / 14

文档供参考,可复制、编制,期待您的好评与关注!

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

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

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

A) C程序在运行过程中所有计算都以二进制方式进行 B)C程序在运行过程中所有计算都以十进制方式进行 C)所有C程序都需要编译链接无误后才能运行

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

(14)有以下定义:int a; long b; double x,y;则以下选项中正确的表达式是

A)a%(int)(x-y) B)a=x!=y; C)(a*y)%b D)y=x+y=x

(15)以下选项中能表示合法常量的是 A)整数:1,200 B)实数:1.5E2.0 C )字符斜杠:‘\\’ D)字符串:\"\\007\"

(16)表达式a+=a-=a=9的值是 A)9 B)_9 C)18 D)0

(17)若变量已正确定义,在if (W)printf(“%d\\n,k”);中,以下不可替代W的是 A)a<>b+c B)ch=getchar() C)a==b+c D)a++

3 / 14

文档供参考,可复制、编制,期待您的好评与关注!

(18)有以下程序 #include main()

{int a=1,b=0; if(!a) b++;

else if(a==0)if(a)b+=2; else b+=3;

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

程序运行后的输出结果是 A)0 B)1 C)2 D)3

(19)若有定义语句int a, b;double x;则下列选项中没有错误的是 A)switch(x%2) B)switch((int)x/2.0 {case 0: a++; break; {case 0: a++; break; case 1: b++; break; case 1: b++; break; default : a++; b++; default : a++; b++; } }

C)switch((int)x%2) D)switch((int)(x)%2) {case 0: a++; break; {case 0.0: a++; break; case 1: b++; break; case 1.0: b++; break; default : a++; b++; default : a++; b++; } } (20)有以下程序 #include main()

{int a=1,b=2;

while(a<6){b+=a;a+=2;b%二10;} printf(”%d,%d\n”,a,b); }

程序运行后的输出结果是 A)5,11 B)7,1 C)7,11

4 / 14

文档供参考,可复制、编制,期待您的好评与关注!

D)6,1

(21)有以下程序 #include<stdio.h> main() {int y=10; while(y--);

printf(”Y=%d\n”,Y); }

程序执行后的输出结果是 A)y=0 B)y= -1 C)y=1

D)while构成无限循环 (22)有以下程序 #include<stdio .h> main()

{char s[」=”rstuv\"; printf(”%c\n”,*s+2); }

程序运行后的输出结果是 A)tuv

B)字符t的ASCII码值 C)t D)出错

(23)有以下程序 #include<stdio.h> #include<string.h> main()

{char x[]=”STRING”;

x[0」=0;x[1]=’\0’;x[2」=’0’; printf(”%d %d\\n”,sizeof(x),strlen(x)); }

程序运行后的输出结果是 A)6 1 B)7 0 C)6 3

5 / 14

文档供参考,可复制、编制,期待您的好评与关注!

D)7 1

(24)有以下程序 #include<stdio.h> Int f(int x); main() {int n=1,m;

m=f(f(f(n)));printf(”%d\n”,m); }

int f(int x) {return x*2;} 程序运行后的输出结果是 A)1 B)2 C)4 D)8

(25)以下程序段完全正确的是 A)int *p; scanf(\"%d\&p); B)int *p; scanf(“%d”,p); C)int k, *p=&k; scanf(\"%d\);

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

(26)有定义语句:int *p[4];以下选项中与此语句等价的是 A)int p[4]; B)int **p; C)int *(p「4」); D)int (*p)「4」;

(27)下列定义数组的语句中,正确的是 A)int N=10; B)#define N 10 int x[N]; int x[N]; C)int x[0..10]; D)int x[];

(28)若要定义一个具有5个元素的整型数组,以下错误的定义语句是 A)int a[5]=﹛0﹜; B)int b[]={0,0,0,0,0}; C)int c[2+3];

6 / 14

文档供参考,可复制、编制,期待您的好评与关注!

D)int i=5,d[i];

(29)有以下程序 #include<stdio.h> void f(int *p); main()

{int a[5]={1,2,3,4,5},*r=a; f(r);printf(”%d\\n”;*r); }

void f(int *p)

{p=p+3;printf(”%d,”,*p);} 程序运行后的输出结果是 A)1,4 B)4,4 C)3,1 D)4,1

(30)有以下程序(函数fun只对下标为偶数的元素进行操作) # include<stdio.h> void fun(int*a;int n) {int i、j、k、t;

for (i=0;i<n一1;1+=2) {k=i;‘

for(j=i;ja〔k])k=j; t=a〔i];a〔i]=a[k];a〔k]=t; } } main()

{int aa「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

7 / 14

文档供参考,可复制、编制,期待您的好评与关注!

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

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

C)if(strcpy(s l ,s2)==1)ST; D)if(sl-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<stdio.h> #include<string .h> main()

{char a[20]=”ABCD\OEFG\0”,b[]=”IJK”; strcat(a,b);printf(”%s\\n”,a); }

程序运行后的输出结果是 A)ABCDE\\OFG\\OIJK B)ABCDIJK C)IJK D)EFGIJK

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

#include<stdio.h> #include<ctype.h> void fun(char*p) {int i=0; while (p[i])

{if(p[i]==’ ’&& islower(p「i-1」))p[i-1]=p[i-1]-‘a’+‘A’; i++; } }

8 / 14

文档供参考,可复制、编制,期待您的好评与关注!

main()

{char s1[100]=”ab cd EFG!”; fun(s1); printf(”%s\\n”,s1); }

程序运行后的输出结果是 A)ab cd EFG! B)Ab Cd EFg! C)aB cD EFG! D)ab cd EFg! (35)有以下程序 #include<stdio.h> void fun(int x)

{if(x/2>1)fun(x/2); printf(”%d”,x); } main()

{fun(7);printf(”\\n”);} 程序运行后的输出结果是 A)1 3 7 B)7 3 1 C)7 3 D)3 7

(36)有以下程序 #include<stdio.h> int fun() {static int x=1; x+=1;return x; } main() {int i;s=1;

for(i=1;i<=5;i++)s+=fun(); printf(”%d\n”,s); }

程序运行后的输出结果是 A)11 B)21

9 / 14

文档供参考,可复制、编制,期待您的好评与关注!

C)6 D)120

(37)有以下程序 #inctude<stdio.h> #include<stdlib.h> 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,3 B)2,2,3 C)1,2,3 D)1,1,3

(38)有以下程序 #include<stdio.h> main()

{int s,t,A=10;double B=6; s=sizeof(A);t=sizeof(B); printf(“%d,%d\n”,s,t); }

在VC6平台上编译运行,程序运行后的输出结果是 A)2,4 B)4,4 C)4,8 D)10,6

(39)若有以下语句 Typedef struct S {int g; char h;}T; 以下叙述中正确的是 A)可用S定义结构体变量 B)可用T定义结构体变量 C)S是struct类型的变量 D)T是struct S类型的变量

(40)有以下程序 #include<stdio.h> main()

10 / 14

文档供参考,可复制、编制,期待您的好评与关注!

{short c=124; c=c_______;

printf(“%d\n”、C); }

若要使程序的运行结果为248,应在下划线处填入的是 A)>>2 B)|248 C)&0248 D)<请将每空的正确答案写在答题卡【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】。 #include<stdio.h> main()

{int a=200,b=010; printf(”%d%d\\n”,a,b); }

(7)有以下程序 #include<stdio.h> main() {int x,Y;

scanf(”%2d%ld”,&x,&y);printf(”%d\n”,x+y); }

程序运行时输入:1234567程序的运行结果是【7】。

11 / 14

文档供参考,可复制、编制,期待您的好评与关注!

(8)在C语言中,当表达式值为0时表示逻辑值“假”,当表达式值为【8】时表示逻辑值“真”。 (9)有以下程序 #include<stdio.h> main()

{int i,n[]={0,0,0,0,0}; for (i=1;i<=4;i++)

{n[i]=n[i-1]*3+1; printf(”%d \);} }

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

(10)以下fun函数的功能是:找出具有N个元素的一维数组中的最小值,并作为函数值返回。请填空。(设N已定义) int fun(int x[N]) {int i,k=0; for(i=0;i(11)有以下程序 #include<stdio.h> int*f(int *p,int*q); main()

{int m=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已定义) int fun(int a[N][M)) {int i,j,row=0,col=0; for(i=0;i12 / 14

文档供参考,可复制、编制,期待您的好评与关注!

for(j=0;j

if(a[i][j]>a[row][col]){row=i;col=j;} return(【12】): }

(13)有以下程序 #include<stdio.h> main()

{int n[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<stdio.h> main()

{int a〔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<stdio.h> main() {【15】*fp;

char a[5]={’1’,’2’,’3’,’4’,’5’},i; fp=fopen(”f .txt”,”w”);

for(i=0;i<5;i++)fputc(a[i],fp); fclose(fp); }

13 / 14

文档供参考,可复制、编制,期待您的好评与关注!

温馨提示-专业文档供参考,请仔细阅读后下载,最好找专业人士审核后使用!

14 / 14

因篇幅问题不能全部显示,请点此查看更多更全内容

Copyright © 2019- shangjiatang.cn 版权所有 湘ICP备2022005869号-4

违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务