计算机二级考试c语言题库(计算机二级C语言题型有哪些)

2024-04-17 11:11:24

全国计算机二级C语言程序设计包括40个单选题(每题一分)和三道操作题(60分)。

单选题中1~10题为二级公共基础知识,单选题的11~40题是C语言的内容。

操作题包括程序填空(18分)、程序改错(18分)和编程题(24分)各一题。

程序填空是将一个完整的程序,扣掉两到三处,让考生将它填写完整。由于每位考生具体抽到的题目不同,程序填空有2到3个空要填。

程序改错也是一个完整的程序,其中有2~3处错误要求考生将他们改正。

编程题是要求考生编写一个程序,然后运行出题干要求的结果。题目中主函数main()会完整给出,在主函数中将调用fun()函数,fun函数由考生自己编写。编程题以运行结果给分,所编写完成后必须运行,否则没分。

二级C语言程序设计考试涉及公共基础知识和C语言两块。公共基础知识内容包括数据结构与算法、程序设计基础、软件工程基础、数据库设计基础四部分。考10个单选每个1分。

C语言有基础知识(C语言概述、常量与变量、数据类型、运算符和表达式),编程三大结构(顺序结构、选择结构、循环结构),数组、函数和指针,其他内容(预处理命令、结构体和共用体、位运算、文件)四大部分内容。重点是第二、三部分。

求09年3月份全国计算机等级考试二级c语言笔试试题的详细讲解

05年4月全国计算机二级C语言考试试题及答案

(1)数据的存储结构是指 D

(A)存储在外存中的数据 (B)数据所占的存储空间量

(C)数据在计算机中的顺序存储方式 (D)数据的逻辑结构在计算机中的表示

(2)下列关于栈的描述中错误的是 B

(A)栈是先进后出的先性表

(B)栈只能顺序存储

(C)栈具有记忆作用

(D)对栈的插入和删除操作中,不需要改变栈底指针

(3)对于长度为N的线性表,在最坏的情况下,下列各排序法所对应的比较次数中正确的是D

(A)冒泡排序为N/2 (B)冒泡排序为N

(C)快速排序为N (D)快速排序为N(N-1)/2

(4)对长度为N的线性表进行顺序查找,在最坏的情况下所需要的比较次数为 C

(A)log2n (B)n/2 (C)n (D)n+1

(5)下列对于线性表的描述中正确的是 A

A)存储空间不一定是连续,且各元素的存储顺序是任意的

B)存储空间不一定是连续,且前件元素一定存储在后件元素的前面

C)存储空间必须连续,且各前件元素一定存储在后件元素的前面

D)存储空间必须连续,且各元素的存储顺序是任意的

(6)下列对于软件测试的描述中正确的是 C

A)软件测试的目的是证明程序是否正确

B)软件测试的目的是使程序运行结果正确

C)软件测试的目的是尽可能地多发现程序中的错误

D)软件测试的目的是使程序符合结构化原则

(7)为了使模块尽可能独立,要求 B

(A)模块的内聚程度要尽量高,且各模块间的耦合程度要尽量强

(B)模块的内聚程度要尽量高,且各模块间的耦合程度要尽量弱

(C)模块的内聚程度要尽量低,且各模块间的耦合程度要尽量弱

(D)模块的内聚程度要尽量低,且各模块间的耦合程度要尽量强

(8)下列描述中正确的是 D

(A)程序就是软件 (B)软件开发不受计算机系统的限制

(C)软件既是逻辑实体,又是物理实体 (D)软件是程序、数据与相关文档的集合

(9)数据独立性是数据库技术的重要特点之一.所谓数据独立性是指 D

(A)数据与程序独立存放

(B)不同的数据被存放在不同的文件中

(C)不同的数据只能被对应的应用程序所使用

(D)以上三种说法都不对

(10)用树形结构表示实体之间联系的模型是 C

(A)关系模型 (B)网状模型 (C)层次模型 (D)以上三个都是

(11)算法具有五个特性,以下选项中不属于算法特性的是 B

(A)有穷性 (B)简洁性 (C)可行性 (D)确定性

(12)以下选项中可作为C语言合法常量的是 A

(A)-80. (B)-080 (C)-8e1.0 (D)-80.0e

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

(A)用C语言实现的算法必须要有输入和输出操作

(B)用C语言实现的算法可以没有输出但必须要有输入

(C)用C程序实现的算法可以没有输入但必须要有输出

(D)用C程序实现的算法可以既没有输入也没有输出

(14)以下不能定义为用户标识符是 D

(A)Main (B)_0 (C)_int (D)sizeof

(15)以下选项中,不能作为合法常量的是 B

(A)1.234e04 (B)1.234e0.4 (C)1.234e+4 (D)1.234e0

(16)数字字符0的ASCII值为48,若有以下程序 C

main()

{

char a=’1’,b=’2’;

printf("%c,",b++);

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

}

程序运行后的输出结果是

(A)3,2 (B)50,2 (C)2,2 (D)2,50

(17)有以下程序 A

main()

{

int m=12,n=34;

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

}

程序运行后的输出结果是

(A)12353514 (B)12353513 (C)12343514 (D)12343513

(18)有以下语句:int b;char c[10];,则正确的输入语句是 B

A)scanf("%d%s",&b,&c); B) scanf("%d%s",&b,c);

c)scanf("%d%s",b,c); D)scanf("%d%s",b,&c);

(19)有以下程序 A

main()

{

int m,n,p;

scanf("m=%dn=%dp=%d",&m,&n,&p);

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

}

若想从键盘上输入数据,使变量M中的值为123,N中的值为456,P中的值为789,则正确的输入是

A)M=123N=456P=789 B)M=123 N=456 P=789 C)M=123,N=456,P=789 D)123 456 789

(20)有以下程序 B

main()

{

int a,b,d=25;

a=d/10%9;b=a&&(-1);

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

}

程序运行后的输出结果是

A)6,1 B)2,1 C)6,0 D)2,0

(21)有以下程序 D

main()

{

int i=1,j=2,k=3;

if(i++==1&&(++j==3||k++==3))

printf("%d %d %d\n",i,j,k);

}

程序运行后的输出结果是

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

(22)若整型变量a、b、c、d中的值依次为:1、4、3、2。

则条件表达式aA) 1 B)2 C)3 D)

(23)有以下程序 B

main()

{

int p[8]={11,12,13,14,15,16,17,18},i=0,j=0;

while(i++<7) if(p[i]%2) j+=p[i];

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

}

程序运行后的输出结果是

A)42 B)45 C)56 D)60

(24)有以下程序 C

main()

{

char a[7]="a0\0a0\0"; int i,j;

i=sizeof(a); j=strlen(a);

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

}

程序运行后的输出结果是

A)2 2 B)7 6 C)7 2 D)6 2

(25)以下能正确定义一维数组的选项是 B

A)int a[5]={0,1,2,3,4,5}; B)char a[]={0,1,2,3,4,5};

C)char a={’A’,’B’,’C’}; D)int a[5]="0123";

(26)有以下程序 A

int f1(int x,int y){return x>y?x:y;}

int f2(int x,int y){return x>y?y:x;}

main()

{

int a=4,b=3,c=5,d=2,e,f,g;

e=f2(f1(a,b),f1(c,d)); f=f1(f2(a,b),f2(c,d));

g=a+b+c+d-e-f;

printf("%d,%d,%d\n",e,f,g);

}

程序运行后的输出结果是

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

27)已有定义:char a[]="xyz",b[]={’x’,’y’,’z’};,以下叙述中正确的是 C

A)数组a和b的长度相同 B)a数组长度小于b数组长度

C)a数组长度大于b数组长度 D)上述说法都不对

28)有以下程序 D

void f(int *x,int *y)

{

int t;

t=*x;*x=*y;*y=t;

}

main()

{

int a[8]={1,2,3,4,5,6,7,8},i,*p,*q;

p=a;q=&a[7];

while(p{f(p,q);p++;q--;}

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

}

程序运行后的输出结果是

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

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

29)有以下程序 D

main()

{

int a[3][3],*p,i;

p=&a[0][0];

for(i=0;i<9;i++)p[i]=i;

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

}

程序运行后的输出结果是

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

(30)以下叙述中错误的是 A

A)对于double类型数组,不可以直接用数组名对数组进行整体输入或输出

B)数组名代表的是数组所占存储区的首地址,其值不可改变

C)当程序执行中,数组元素的下标超出所定义的下标范围时,系统将给出"下标越界"的出错信息

D)可以通过赋初值的方式确定数组元素的个数

(31)有以下程序 C

#define N 20

fun(int a[],int n,int m)

{int i,j;

for(i=m;i>=n;i--)a[i+1]=a[i];

}

main()

{

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

fun(a,2,9);

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

}

程序运行后的输出结果是

A)10234 B)12344 C)12334 D)12234

32)有以下程序 B

main()

{

int a[3][2]={0},(*ptr)[2],i,j;

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

{ptr=a+i;scanf("%d",ptr);ptr++;}

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

{for(j=0;j<2;j++)printf("-",a[i][j]);

printf("\n");

}

}

若运行时输入:1 2 3<回车>,则输出结果是

A)产生错误信息 B)1 0 C)1 2 D)1 0

2 0 3 0 2 0

0 0 0 0 3 0

33)有以下程序 B

prt(int *m,int n)

{int i;

for(i=0;i)

main()

{

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

prt(a,5);

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

printf("%d,",a[i]);

}

程序运行后的输出结果是

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

34)有以下程序 A

main()

{int a[]={1,2,3,4,5,6,7,8,9,0},*p;

for(p=a;p}

程序运行后的输出结果是

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

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

35)有以下程序 D

#define P 3

void F(int x){return(P*x*x);}

main()

{printf("%d\n",F(3+5));}

程序运行后的输出结果是

A)192 B)29 C)25 D)编译出错

36)有以下程序 C

main()

{int c=35;printf("%d\n",c&c);}

程序运行后的输出结果是

A)0 B)70 C)35 D)1

37)以下叙述中正确的是 D

A)预处理命令行必须位于源文件的开头

B)在源文件的一行上可以有多条预处理命令

C)宏名必须用大写字母表示

D)宏替换不占用程序的运行时间

38)若有以下说明和定义 C

union dt

{int a;char b;double c;}data;

以下叙述中错误的是

A)data的每个成员起始地址都相同

B)变量data所占的内存字节数与成员c所占字节数相等

C)程序段:data.a=5;printf("%f\n",data.c);输出结果为5.000000

D)data可以作为函数的实参

39)以下语句或语句组中,能正确进行字符串赋值的是 C

A)char *sp;*sp="right!"; B)char s[10];s="right!";

C)char s[10];*s="right!"; D)char *sp="right!";

40)设有如下说明 C

typedef struct ST

{long a;int b;char c[2];}NEW;

则下面叙述中正确的是

A)以上的说明形式非法 B)ST是一个结构体类型

C)NEW是一个结构体类型 D)NEW是一个结构体变量

41)有以下程序 B

main()

{int a=1,b;

for(b=1;b<=10;b++)

{if(a>=8)break;

if(a%2==1){a+=5;continue;}

a-=3;

}

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

}

程序运行后的输出结果是

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

42)有以下程序 A

main()

{char s[]="159",*p;

p=s;

printf("%c",*p++);printf("%c",*p++);

}

程序运行后的输出结果是

A)15 B)16 C)12 D)59

43)有以下函数 D

fun(char *a,char *b)

{while((*a!=’\0’)&&(*b!=’\0’)&&(*a==*b))

{a++;b++;}

return(*a-*b);

}

该函数的功能是

A)计算a和b所指字符串的长度之差

B)将b所指字符串连接到a所指字符串中

C)将b所指字符串连接到a所指字符串后面

D)比较a和b所指字符串的大小

44)有以下程序 B

main()

{int num[4][4]={{1,2,3,4},{5,6,7,8},{9,10,11,12},{13,14,15,16}},i,j;

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

{for(j=0;j<=i;j++)printf("L",’ ’);

for(j=_____;j<4;j++)printf("M",num[i][j]);

printf("\n");

}

}

若要按以下形式输出数组右上半三角

1 2 3 4

6 7 8

11 12

16

则在程序下划线处应填入的是

A)i-1 B)i C)i+1 D)4-i

45)有以下程序 D

point(char *p){p+=3;}

main()

{char b[4]={’a’,’b’,’c’,’d’},*p=b;

point(p);printf("%c\n",*p);

}

程序运行后的输出结果是

A)a B)b C)c D)d

46)程序中若有如下说明和定义语句 A

char fun(char *);

main()

{

char *s="one",a[5]={0},(*f1)()=fun,ch;

......

}

以下选项中对函数fun的正确调用语句是

A)(*f1)(a); B)*f1(*s); C)fun(&a); D)ch=*f1(s);

47)有以下结构体说明和变量定义,如图所示,

指针p、q、r分别指向此链表中的三个连续结点。

struct node

{int data;struct node *next;}*p,*q,*r;

现要将Q所指结点从链表中删除,同时要保持链表的连续,

以下不能完成指定操作的语句是 D

A)P->next=q->next; B)p->next=p->next->next;

c)p->next=r; D)p=q->next;

48)以下对结构体类型变量td的定义中,错误的是 C

A)typedef struct aa B)struct aa C)struct D)struct

{int n; {int n; {int n; {int n;

float m; float m; float m; float m;

}AA; }td; }aa; }td;

AA td; struct aa td; struct aa td;

49)以下与函数fseek(fp,0L,SEEK_SET)有相同作用的是 D

A)feof(fp) B)ftell(fp) C)fgetc(fp) D)rewind(fp)

50)有以下程序 B

#include

void WriteStr(char *fn,char *str)

{FILE *fp;

fp=fopen(fn,"w");fputs(str,fp);fclose(fp);

}

main()

{

WriteStr("t1.dat","start");

WriteStr("t1.dat","end");

}

程序运行后,文件t1.dat中的内容是

A)start B)end C)startend D)endrt

1.某二叉树中度为2的结点有18个,则该二叉树中有______个叶子结点。

答案:19

2.在面向对象方法中,类的实例称为____.

答案:对象

3.诊断和改正程序中错误的工作通常称为______.

答案:调试

4.在关系数据库中,把数据表示成二维表,每一个二维表称为_____

答案:关系

5.问题处理方案的正确而完整的描述称为___

答案:算法

6.以下程序运行时若从键盘输入:10 20 30<回车>.输出结果是______

#include

main()

{

int i=0,j=0,k=0;

scanf("%d%*d%d",&i,&j,&k);printf("%d%d%d\n",i,j,k);

}

答案:10 30 0

7.以下程序运行后的输出结果是____

#define S(x) 4*x*x+1

main()

{

int i=6,j=8;

printf("%d\n",S(i+j));

}

答案:81

*8.以下程序运行后的输出结果是_____

main()

{int a=3,b=4,c=5,t=99;

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

}

答案:4399

9.以下程序运行后的输出结果是____

main()

{

int a,b,c;

a=10;b=20;c=(a%b<1)||(a/b>1);

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

}

答案:10 20 0

10.以下程序运行后的输出结果是___

main()

{char c1,c2;

for(c1=’0’,c2=’9’;c1printf("\n");

)

答案:0918273645

11.已知字符A的ASCII代码值为65,以下程序运行时若从键盘输入:B33<回车>.则

输出结果是_____

#include

main()

{char a,b;

a=getchar();scanf("%d",&b);

a=a-’A’+’0’;b=b*2;

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

}

答案:1 B

12.以下程序中,fun函数的功能是求3行4列二维数组每行元素中的最大值.请填空

void fun(int,int,int(*)[4],int *);

main()

{int a[3][4]={{12,41,36,28},{19,33,15,27},{3,27,19,1}},b[3],i;

fun(3,4,a,b);

for(i=0;i<3;i++)printf("M",b[i]);

printf("\n");

}

void fun(int m,int n,int ar[][4],int *bar)

{

int i,j,x;

for(i=0;i {x=ar[i][0];

for(j=0;j ________=x;

)

}

)

答案:bar[i]

13.以下程序运行后的输出结果是______

void swap(int x,int y)

{ int t;

t=x;x=y;y=t;printf("%d %d ",x,y);

}

main()

{ int a=3,b=4;

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

}

答案:4 3 3 4

14.以下程序运行后的输出结果是____

#include

void fun(char *s,int p,int k)

{int i;

for(i=p;i)

main()

{char s[]="abcdefg";

fun(s,3,strlen(s));puts(s);

}

答案:abcfg

17.以下程序运行后的输出结果是______

struct NODE

{int k;

struct NODE *link;

};

main()

{ struct NODE m[5],*p=m,*q=m+4;

int i=0;

while(p!=q)

{p->k=++i;p++;

q->k=i++;q--;

}

q->k=i;

for(i=0;i<5;i++)printf("%d",m[i].k);

printf("\n");

}

答案:13431

18.以下程序中函数huiwen的功能是检查一个字符串是否是回文,当字符串是回文时,

函数返回字符串:yes!,否则函数返回字符串:no!,并在主函数中输出.所谓回文即

正向与反向的拼写都一样,例如:adgda.请填空.

#include

char *huiwen(char *str)

{char *p1,*p2;int i,t=0;

p1=str;p2=______;

for(i=0;i<=strlen(str)/2;i++)

if(*p1++!=*p2--){t=1;break;}

if(____)return("yes!");

else return("no!");

}

main()

{char str[50];

printf("Input:");scanf("%s",str);

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

}

答案:18) str+(strlen(str)-1)

19) !t

20) huiwen(str)

09年3月全国计算机等级考试二级C笔试真题(附答案)(考试时间90分钟,满分100分)一、选择题(1)下列叙述中正确的是 A) 栈是先进先出(FIFO)的线性表B) 队列是先进先出(FIFO)的线性表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)程序调试通常也称为DebugD)软件测试应严格执行测试计划,排除测试的随意性(7)耦合性和内聚性是对模块独立性度量的两个标准。下列叙述中正确的是 A)提高耦合性降低内聚性有利于提高模块的独立性B)降低耦合性提高内聚性有利于提高模块的独立性C)耦合性是指一个模块内部各个元素间彼此结合的紧密程度D)内聚性是指模块间互相连接的紧密程度(8)数据库应用系统中的核心问题是A)数据库设计 B)数据库系统设计C)数据库维护 D) 数据库管理员培训(9)有两个关系R,S如下:R SA B C A Ba 3 2 a 3b 0 1 b 0c 2 1 c 2 由关系R通过运算得到关系S,则所使用的运算为A) 选择 B)投影 C) 插入 D)连接(10)将E-R图转换为关系模式时,实体和联系都可以表示为A) 属性 B)键 C) 关系 D) 域(11)以下选项中合法的标识符是 A) 1-1 B)1—1 C)-11 D)1--(12)若函数中有定义语句:int k;,则 A)系统将自动给k赋初值0 B)这时k中值无定义 C)系统将自动给k赋初值-1 D)这时k中无任何值(13)以下选项中,能用作数据常量的是 A)o115 B) 0118 C)1.5e1.5 D) 115L(14)设有定义:int x=2; ,以下表达式中,值不为6的是A) x*=x+1 B) x++,2*x C)x*=(1+x) D)2*x,x+=2(15)程序段:int x=12; double y=3.141593; printf(“%d%8.6f”,x,y);的输出结果是A)123.141593 B)12 3.141593 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 <stdio.h>main(){int x;</p><p>scanf(“%d”,&x);</p><p>if(x<=3); else</p><p>if(x!=10) printf(“%d\n”,x);</p><p>}程序运行时,输入的值在哪个范围才会有输出结果A)不等于10的整数 B)大于3且不等于10的整数C) 大于3或等于10的整数 D)小于3的整数(19)有以下程序#include<stdio.h>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<stdio.h>main(){char *s=(“ABC);</p><p>do</p><p>{printf(“%d”,*s%10);s++;</p><p>}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<stdio.h>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,则正确的输入格式是(以下 代表空格,<CR>代表回车)A)12a34b<CR> B)12 a 34 b<CR>C)12,a,34,b<CR> D)12 a34 b<CR>(24)有以下程序#include<stdio.h>int f(int x,int y){return()y-x)*x);}main(){int a=3,b=4,c=5,d;</p><p>d=f(f(a,b),f(a,c));</p><p>printf(“%d\n”,d);</p><p>}程序运行后的输出结果是A)10 B)9 C)8 D)7(25)有以下程序#include<stdio.h>void fun(char *s){while(*s)</p><p> { if(*s%2==0) printf(“%c”,*s);</p><p>s++;</p><p> }}main(){ char a[]={“good”}; fun(a);printf(“\n”);}注意:字母a的ASCII码值为97,程序运行后的输出结果是A)d B)go C)god D)good(26)有以下程序#include <stdio.h>void fun( int *a,int *b){int *c;</p><p>c=a;a=b;b=c;</p><p>}main(){int x=3,y-5,*P=&x,*q=&y;</p><p> fun(p,q);printf(“%d,%d,”,*p,*q);</p><p>fun(&x,&y);printf(“%d,%d\n”,*p,*q);</p><p>}程序运行后的输出结果是A)3,5,5,3 B)3,5,3,5 C)5,3,3,5 D)5,3,5,3(27)有以下程序#include <stdio.h>void 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<n;i++) {________</p><p> printf(“%d”,w);</p><p> } printf(“\n”);}下划线处应填入的语句是A)if(i/8==0)print(“\n”); B) if(i/8==0)continue;C) if(i%8==0)print(“\n”); D) if(i%8==0)continue;(29)若有以下定义 int x[10],*pt=x;则对x数组元素的正确应用是A)*&x[10] B)*(x+3) C)*(pt+10) D)pt+3 (30)设有定义:char s[81];int i=10;,以下不能将一行(不超过80个字符)带有空格的字符串真确读入的语句或语句组是A gets(s) B)while((s[i++]=getchar())!=”\n”;s=”\0”;C)scanf(“%s”,s);D)do{scanf(“%c”,&s);}while(s[i++]!=”\n”);s=”\0”;(31)有以下程序#include <stdio.h>main(){ char *a[ ]={“abcd”,”ef”,”gh”,”ijk”};int I; for (i=0;i<4;i++) printf(“%c”,*a);}程序运行后输出的结果是A)aegi B)dfhk C)abcd D)abcdefghijk(32)以下选项中正确的语句组是A)char s[];s=”BOOK!”; B) char *s;s={”BOOK!”};C)char s[10];s=”BOOK!”; D) char *s;s=”BOOK!”;(33)有以下程序#include <stdio.h>int fun{int x,int y}{ if(x==y) return(x); else return((x+y)/2)}main(){ int a=4,b=5,c=6; printf(“%d\n”,fun(2*a,fun(b,c)))}程序运行后的输出结果是A)3 B)6 C)8 D)12(34)设函数中有整型变量n,为保证其在未赋值的情况下初值为0,应选择的存储类别是A)auto B) register C)static D)auto或register(35)有以下程序#include <stdio.h>int b=2;int fun(int *k){ b=*k+b;return(b);}main(){ int a[10]={1,2,3,4,5,6,7,8},I; for(i=2;i<4;i++) {b=fun(&a)+b;printf(“%d”,b);} printf(“\n”);}程序运行后输出的结果是A)10 12 B)8 10 C)10 28 D)10 16(36)有以下程序#include <stdio.h>#define PT 3.5;#define S(x) PT*x*x;main(){ int a=1, b=2; printf(“%4.1f\n”,S(a+b));}程序运行后输出的结果是A)14.0 B)31.5 C)7.5 D)程序有错无输出结果(37)有以下程序#include <stdio.h>struct ord{ int x,y;} dt[2]={1,2,3,4};main(){ struct ord *p=dt; printf (“%d,”,++p->x); printf(“%d\n”,++p->y);}程序的运行结果是A)1,2 B)2,3 C)3,4 D)4,1(38)设有宏定义:#include IsDIV(k,n) ((k%n==1)?1:0且变量m已正确定义并赋值,则宏调用:IsDIV(m,5)&& IsDIV(m,7)为真时所要表达的是A)判断m是否能被5或者7整除B)判断m是否能被5和7整除C)判断m被5或者7整除是否余1D)判断m被5和7整除是否余1(39)有以下程序#include <stdio.h>main(){ int a=5,b=1,t; t=(a<<2|b); printf(“%d\n”,t) }程序运行后的输出结果是A)21 B)11 C)6 D)1(40)有以下程序#include <stdio.h>main(){ FILE *f; f=fopen(“filea.txt”,”w”); fprintf(f,”abc”); fclose(f);}若文本文件filea.txt中原有内容为:hello,则运行以上程序后,文件filea.txt中的内容为A) helloabc B)abclo C)abc D)abchello 二、填空题(每空2分,共30分) 请将每一个空的正确答案写在答题卡1至15序号的横线上,答在试卷上不得分。(1)假设一个长度为50的数组(数组元素的下标从0到49)作为栈的存储空间,栈底指针bottom指向栈底元素,栈顶指针top指向栈顶元素,如果bottom=49,top=30(数组下标),则栈中具有 1 个元素。(2)软件测试可分为白盒测试和黑盒测试。基本路径测试属于 2 测试。(3)符合结构化原则的三种基本控制结构是:选择结构、循环结构和 3 。(4)数据库系统的核心是 4(5)在E-R图中,图形包括矩形框、菱形框、椭圆框。其中表示实体联系的是 5 框。(6)表达式(int)((double)(5/2)+2.5)的值是6(7)若变量x、y已定义为int类型且x的值为99,y的值为9,请将输出语句printf(7,x/y);补充完整,使其输出的计算结果形式为:x/y=11(8)有以下程序#include <stdio.h>main( ){ char c1,c2; scanf(“&c”,&c1); while(c1<65||c1>90) scanf(“&c”,&c1); c2=c1+32; printf(“&c, &c\n”,c1,c2);}程序运行输入65回车后,能否输出结果、结束运行(请回答能或不能)8 。 (9)以下程序运行后的输出结果是9#include <stdio.h>main( ){int k=1,s=0;</p><p>do{</p><p>if{((k&2)!=0)continue;</p><p>s+=k;k++;</p><p>}while(k)10);printf(“s=&d/n”,s);} (10)下列程序运行时,若输入labced12df<回车> 输出结果为10 #include <stdio.h>main( ){char a =0,ch;</p><p>while((ch=getchar())!=’\n’)</p><p>{if(a&2!=0&&(ch>’a’&&ch<=’z’)) ch=ch-‘a’+’A’;</p><p>a++;putchar(ch);</p><p>}printf(“\n”);}(11)有以下程序,程序执行后,输出结果是11#include <stdio.h>void fun (int *a){a[0=a[1];]}main(){int a[10]={10,9,8,7,6,5,4,3,2,1},i;for(i=2;i>=0;i--) fun{&a};for(i=0;i<10;i++) printf(“&d”,a);printf(“\n”);}(12)请将以下程序中的函数声明语句补充完整#include <stdio.h>int12 ;main( ){int x,y,(*p)();</p><p>p=max;</p><p>printf(“&d\n”,&x,&y);</p><p>}Int max(int a,int b){return (a>b/a:b);}(13)以下程序用来判断指定文件是否能正常打开,请填空#include <stdio.h>main( ){FILE *fp;</p><p>if (((fp=fopen(“test.txt”,”r”))==13))</p><p>printf(“未能打开文件!\n”);</p><p>else</p><p>printf(“文件打开成功!\n”);</p><p>(14)下列程序的运行结果为14</p><p>#include <stdio.h></p><p>#include <string.h></p><p>struct A</p><p>{int a;char b[10];double c;};void f (struct A *t);main(){struct A a=(1001,”ZhangDa”,1098,0);</p><p>f(&a);printf(“&d,&s,&6,if\n”,a.a,a.b,a.c);</p><p>}void f(struct A *t){strcpy(t->b,”ChangRong”); }(15)以下程序把三个NODETYPE型的变量链接成一个简单的链表,并在while循环中输出链表结点数据域中的数据,请填空#include <stdio.h>struct node{int data; struct node *next;};typedef struct node NODETYPE;main(){NODETYPE a,b,c,*h,*p;</p><p>a. data=10;b.data=20;c.data=30;h=&a;</p><p>b. next=&b;b.next=&c;c.next=’\0’;</p><p>p=h;</p><p>while(p){printf(“&d”,p->data);15;}} 2009年4月NCRE二级C参考答案选择题:1~10: DACDC ABABC11~20:CBDDA CDBCB21~30:CDABA BACBC31~40:ADBCC CBDAC 填空题:(1)19(2)白盒(3)顺序结构(4)数据库管理系统(DBMS)(5)菱形(6)4(7)"x/y=%d"(8)能(9)s=0(10)1AbCeDf2dF(11)7777654321(12)max(int a,int b)(13)NULL(14)1001,ChangRong,1098.0(15)p=p—>next

TAGS:
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;
2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;
3.作者投稿可能会经我们编辑修改或补充。

搜索
排行榜
标签列表