文档库

最新最全的文档下载
当前位置:文档库 > 《国家计算机二级c语言历年真题及答案》

《国家计算机二级c语言历年真题及答案》

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

C语言程序设计

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

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

(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) 可封装

D) 自顶向下

C) 模块化

D) 逐步求精

(7)软件详细设计产生的图如下:

《国家计算机二级c语言历年真题及答案》

该图是

A) N-S图

B) PAD图

C) 程序流程图

D) E-R图

(8)数据库管理系统是

A)操作系统的一部分

B) 在操作系统支持下的系统软件

C) 一种编译系统

D) 一种操作系统

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

A) 椭圆图

B) 矩形

C) 菱形

D) 三角形

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

《国家计算机二级c语言历年真题及答案》

其中关系T由关系R和S通过某种操作得到,该操作为

A) 选择

B) 投影

C) 交

D) 并

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

A)程序设计的任务就是编写程序代码并上机调试

B)程序设计的任务就是确定所用数据结构

C)程序设计的任务就是确定所用算法

D)以上三种说法都不完整

(12)以下选项中,能用作用户标识符的是

A)void

B)8_8

C)_0_

D)unsigned

(13)阅读以下程序

#include

main()

{ int case; float printF;

printf(“请输入2个数:”);

scanf(“%d %f”,&case,&pjrintF);

printf(“%d %f\n”,case,printF);

}

该程序编译时产生错误,其出错原因是

A)定义语句出错,case是关键字,不能用作用户自定义标识符 B)定义语句出错,printF不能用作用户自定义标识符

C)定义语句无错,scanf不能作为输入函数使用

D)定义语句无错,printf不能输出case的值

(14)表达式:(int)((double)9/2)-(9)%2的值是

A)0

B)3

C)4

D)5

(15)若有定义语句:int x=10;,则表达式x-=x+x的值为

A)-20

B)-10

C)0

D)10

(16)有以下程序

#include

main()

{ int a=1,b=0;

printf(“%d,”,b=a+b);

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

}

程序运行后的输出结果是

A)0,0

C)3,2

D)1,2

17)设有定义:int a=1,b=2,c=3;,以下语句中执行效果与其它三个不同的是

A)if(a>b) c=a,a=b,b=c;

B)if(a>b) {c=a,a=b,b=c;}

C)if(a>b) c=a;a=b;b=c;

D)if(a>b) {c=a;a=b;b=c;}

(18)有以下程序

#include

main()

{ int c=0,k;

for (k=1;k<3;k++)

switch (k)

{ default: c+=k

case 2: c++;break;

case 4: c+=2;break;

}

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

}

程序运行后的输出结果是

A)3

B)5

C)7

D)9

(19)以下程序段中,与语句:k=a>b?(b>c?1:0):0;功能相同的是

A)if((a>b)&&(b>c)) k=1;

else k=0;

B)if((a>b)||(b>c) k=1;

else k=0;

C)if(a<=b) k=0;

else if(b<=c) k=1;

D)if(a>b) k=1;

else if(b>c) k=1;

else k=0;

20)有以下程序

#include

{ char s[]={“012xy”};int i,n=0;

for(i=0;s[i]!=0;i++)

if(s[i]>=’a’&&s[i]<=’z’) n++;

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

}

程序运行后的输出结果是

A)0

B)2

C)3

D)5

(21)有以下程序

#include

main()

{ int n=2,k=0;

while(k++&&n++>2);

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

}

程序运行后的输出结果是

A)0 2

B)1 3

C)5 7

D)1 2

(22)有以下定义语句,编译时会出现编译错误的是

A)char a=’a’;

B)char a=’\n’;

C)char a=’aa’;

D)char a=’\x2d’;

(23)有以下程序

#include

main()

{ char c1,c2;

c1=’A’+’8’-‘4’;

c2=’A’+’8’-‘5’;

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

}

已知字母A的ASCII码为65,程序运行后的输出结果是 A)E,68

C)E,D

D)输出无定值

(24)有以下程序

#include

void fun(int p)

{ int d=2;

p=d++; printf(“%d”,p);}

main()

{ int a=1;

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

程序运行后的输出结果是

A)32

B)12

C)21

D)22

(25)以下函数findmax拟实现在数组中查找最大值并作为函数值返回,但程序中有错导致不能实现预定功能

#define MIN -2147483647

int findmax (int x[],int n)

{ int i,max;

for(i=0;i

{ max=MIN;

if(max

return max;

}

造成错误的原因是

A)定义语句int i,max;中max未赋初值

B)赋值语句max=MIN;中,不应给max赋MIN值

C)语句if(max

D)赋值语句max=MIN;放错了位置

(26)有以下程序

#include

main()

{ int m=1,n=2,*p=&m,*q=&n,*r;

r=p;p=q;q=r;

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

}

程序运行后的输出结果是

A)1,2,1,2

B)1,2,2,1

C)2,1,2,1

D)2,1,1,2

(27)若有定义语句:int a[4][10],*p,*q[4];且0≤i<4,则错误的赋值是

A)p=a

B)q[i]=a[i]

C)p=a[i]

D)p=&a[2][1]

(28)有以下程序

#include

#include

main()

{ char str[ ][20]={“One*World”, “One*Dream!”},*p=str[1];

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

}

程序运行后的输出结果是

A)9,One*World

B)9,One*Dream

C)10,One*Dream

D)10,One*World

(29)有以下程序

#include

main()

{ int a[ ]={2,3,5,4},i;

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

switch(i%2)

{ case 0:switch(a[i]%2)

{case 0:a[i]++;break;

case 1:a[i]--;

}break;

case 1:a[i[=0;

}

for(i=0;i<4;i++) printf(“%d”,a[i]); printf(“\n”);

}

A)3 3 4 4

B)2 0 5 0

C)3 0 4 0

D)0 3 0 4

(30)有以下程序

#include

#include

main()

{ char a[10]=”abcd”;

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

}

程序运行后的输出结果是

A)7,4

B)4,10

C)8,8

D)10,10

(31)下面是有关C语言字符数组的描述,其中错误的是 A)不可以用赋值语句给字符数组名赋字符串

B)可以用输入语句把字符串整体输入给字符数组

C)字符数组中的内容不一定是字符串

D)字符数组只能存放字符串

(32)下列函数的功能是

fun(char * a,char * b)

{ while((*b=*a)!=’\0’) {a++,b++;} }

A)将a所指字符串赋给b所指空间

B)使指针b指向a所指字符串

C)将a所指字符串和b所指字符串进行比较

D)检查a和b所指字符串中是否有’\0’

(33)设有以下函数

void fun(int n,char * s) {……}

则下面对函数指针的定义和赋值均是正确的是

A)void (*pf)(); pf=fun;

B)viod *pf(); pf=fun;

C)void *pf(); *pf=fun;

D)void (*pf)(int,char);pf=&fun;

(34)有以下程序

#include

int f(int n);

main()

{ int a=3,s;

s=f(a);s=s+f(a);printf(“%d\n”,s);

}

int f(int n)

{ static int a=1;

n+=a++;

return n;

}

程序运行以后的输出结果是

A)7

B)8

C)9

D)10

(35)有以下程序

#include

#define f(x) x*x*x

main()

{ int a=3,s,t;

s=f(a+1);t=f((a+1));

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

}

程序运行后的输出结果是

A)10,64

B)10,10

C)64,10

D)64,64

(36)下面结构体的定义语句中,错误的是

A)struct ord {int x;int y;int z;}; struct ord a;

B)struct ord {int x;int y;int z;} struct ord a;

C)struct ord {int x;int y;int z;} a;

D)struct {int x;int y;int z;} a;

(37)设有定义:char *c;,以下选项中能够使字符型指针c正确指向一个字符串的是

A)char str[ ]=”string”;c=str;

B)scanf(“%s”,c);

C)c=getchar();

D)*c=”string”;

(38)有以下程序

#include

#include

struct A

{ int a; char b[10]; double c;};

struct A f(struct A t);

main()

{ struct A a={1001,”ZhangDa”,1098.0};

a=f(a);jprintf(“%d,%s,%6.1f\n”,a.a,a.b,a.c);

}

struct A f(struct A t)

( t.a=1002;strcpy(t.b,”ChangRong”);t.c=1202.0;return t; )

程序运行后的输出结果是

A)1001,ZhangDa,1098.0

B)1001,ZhangDa,1202.0

C)1001,ChangRong,1098.0

D)1001,ChangRong,1202.0

(39)若有以下程序段

int r=8;

printf(“%d\n”,r>>1);

输出结果是

A)16

B)8

C)4

D)2

(40)下列关于C语言文件的叙述中正确的是

A)文件由一系列数据依次排列组成,只能构成二进制文件

B)文件由结构序列组成,可以构成二进制文件或文本文件

C)文件由数据序列组成,可以构成二进制文件或文本文件

D)文件由字符序列组成,其类型只能是文本文件

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

(1)某二叉树有5个度为2的结点以及3个度为1的结点,则该二叉树中共有【1】个结点。

(2)程序流程图中的菱形框表示的是【2】。

(3)软件开发过程主要分为需求分析、设计、编码与测试四个阶段,其中【3】阶段产生“软件需求规格说明书。

(4)在数据库技术中,实体集之间的联系可以是一对一或一对多或多对多的,那么“学生”和“可选课程”的联系为【4】。

(5)人员基本信息一般包括:身份证号,姓名,性别,年龄等。其中可以作为主关键字的是【5】。

(6)若有定义语句:int a=5;,则表达式:a++的值是【6】。

(7)若有语句double x=17;int y;,当执行y=(int)(x/5)%2;之后y的值为【7】。

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

#include

main()

{ int x=20;

printf(“%d”,0

printf(“%d\n”,0

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

#include

main()

{ int a=1,b=7;

do {

b=b/2;a+=b;

} while (b>1);

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

(10)有以下程序

#include

main()

{ int f,f1,f2,i;

f1=0;f2=1;

printf(“%d %d”,f1,f2);

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

{ f=f1+f2; printf(“%d”,f);

f1=f2; f2=f;

}

printf(“\n”);

}

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

(11)有以下程序

#include

int a=5;

void fun(int b)

{ int a=10;

a+=b;printf(“%d”,a);

}

main()

{ int c=20;

fun(c);a+=c;printf(“%d\n”,a);

}

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

(12)设有定义:

struct person

{ int ID;char name[12];}p;

请将scanf(“%d”, 【12】 );语句补充完整,使其能够为结构体变量p的成员ID正确读入数据。

(13)有以下程序

#include

main()

{ char a[20]=”How are you?”,b[20];

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

}

程序运行时从键盘输入:How are you?<回车>

则输出结果为【13】。

(14)有以下程序

#include

typedef struct

{ int num;double s}REC;

void fun1( REC x ){x.num=23;x.s=88.5;}

main()

{ REC a={16,90.0 };

fun1(a);

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

}

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

(15)有以下程序

#include

fun(int x)

{ if(x/2>0) run(x/2);

printf(“%d ”,x);

}

《国家计算机二级c语言历年真题及答案》

二、填空题

2009年3月二级C语言笔试真题及答案

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

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

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

A)栈是“先进先出”的线性表

B)队列是“先进先出”的线性表

C)循环队列是非线性结构

D)有序性表既可以采用顺序存储结构,也可以采用链式存储结构

(2)支持子程序调用的数据结构是

A)栈 B)树 C)队列 D)二叉树

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

A)10 B)8 C)6 D)4

(4)下列排序方法中,最坏情况下比较次数最少的是

A)冒泡排序

B)简单选择排序

C)直接插入排序

D)堆排序

(5)软件按功能可以分为:应用软件、系统软件和支撑软件(或工具软件)。下面属于应用软件的是

A)编译软件

B)操作系统

C)教务管理系统

D)汇编程序

(6)下面叙述中错误的是

A)软件测试的目的是发现错误并改正错误

B)对被调试的程序进行“错误定位”是程序调试的必要步骤

C)程序调试通常也称为Debug

D)软件测试应严格执行测试计划,排除测试的随意性

(7)耦合性和内聚性是对模块独立性度量的两个标准。下列叙述中正确的是A)提高耦合性降低内聚性有利于提高模块的独立性

B)降低耦合性提高内聚性有利于提高模块的独立性

C)耦合性是指一个模块内部各个元素间彼此结合的紧密程度

D)内聚性是指模块间互相连接的紧密程度

《国家计算机二级c语言历年真题及答案》

《国家计算机二级c语言历年真题及答案》

C)12,3.141593

D)123.141593

(16)若有定义语句:double x,y,*px,*py,执行了px=&x, py=&y;之后,正确的输入语句是

A)scanf(“%f%f”,x,y);

B) scanf(“%f%f”,&x,&y);

C) scanf(“%lf%le”,px,py);

D) scanf(“%lf%lf”,x,y);

(17)以下是if语句的基本形式:

if(表达式)

语句

其中“表达式”

A)必须是逻辑表达式

B)必须是关系表达式

C)必须是逻辑表达式或关系表达式

D)可以是任意合法的表达式

(18)有以下程序

#include

main()

{int x;

scanf(“%d”,&x);

if(x<=3); else

if(x!=10)

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

}

程序运行时,输入的值在哪个范围才会有输出结果

A)不等于10的整数

B)大于3且不等于10的整数

C)

大于3或等于10的整数

D)小于3的整数

(19)有以下程序

#include

Main()

{

int a=1,b=2,c=3,d=0;

if(a= =1 &&b++= =2)

if(b!=2 || c--!=3)

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

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

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

}

程序运行后的输出结果是

A)1,2,3

B)1,3,2

C)1,3,3

D)3,2,1

(20)以下程序中的变量已正确定义

for(i=0;i<4;i++,i++

for(k=1;k<3;k++);printf(*”);

程序段的输出结果是

A)********

B)****

C)**

D)*

(21)有以下程序

#include

main()

{char

*s=(“ABC);

do

{printf(“%d”,*s%10);s++;

}while(*s);

}

注意,字母A的ASCII码值为65。程序运行后的输出结果是

A)5670

B)656667

C)567

D)ABC

(22)设变量已正确定义,以下不能统计出一行中输入字符个数(不包含回车符)的程序段是

A)n=0;while((ch=getchar())!=’\n’)n++;

B) n=0;while(getchar()!=’\n’)n++;

C)for(n=0; getchar()!=’\n’;n++);

D)n=0;for(ch=getchar();ch!=’\n’;n++);

(23)有以下程序

#include

main()

{ int a1,a2;char c1,c2;

scanf(“%d%c%d%c”,&a1,&c1,&a2,&c2);

printf(“%d,%c,%d,%c”,&1,c1,a2,c2);

}

若想通过键盘输入,使得a1的值为12,a2的是为34,c1的值为字符a,c2的值为字符b,程序输出结果是:12,a,34,b,则正确的输入格式是(以下

代表空格,代表回车)

A)12a34b

B)12

a

34

b

C)12,a,34,b

D)12

a34

b

(24)有以下程序

#include

int f(int x,int y)

{return()y-x)*x);}

main()

{int a=3,b=4,c=5,d;

d=f(f(a,b),f(a,c));

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

}

程序运行后的输出结果是

A)10

B)9

C)8

D)7

(25)有以下程序

#include

void fun(char

*s)

{while(*s)

{ if(*s%2==0)

printf(“%c”,*s);

s++;

}

}

main()

{ char

a[]={“good”};

fun(a);printf(“\n”);

}

注意:字母a的ASCⅡ码值为97,程序运行后的输出结果是A)d

B)go

C)god

D)good

(26)有以下程序

#include

void fun( int *a,int *b)

{int *c;

c=a;a=b;b=c;

}

main()

{int x=3,y-5,*P=&x,*q=&y;

fun(p,q);printf(“%d,%d,”,*p,*q); fun(&x,&y);printf(“%d,%d\n”,*p,*q); }

程序运行后的输出结果是

A)3,5,5,3

B)3,5,3,5

C)5,3,3,5

D)5,3,5,3

(27)有以下程序

#include

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

main()

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

f(r,&n);printf(“%d,%d”,m,n);

}

void f(int *p,int *q)

{p=p+1;*q=*q+1;}

程序运行后输出的结果是

A)1,3

B)2,3

C)1,4

D)1,2

(28)以下函数按每行8个输出数组中的数据void fun( int *w,int n)

{ int i;

for(i=0;i

{_________________

printf(“%d”,w);

}

TOP相关主题