全国计算机等级考试二级C 语言真题.docx
《全国计算机等级考试二级C 语言真题.docx》由会员分享,可在线阅读,更多相关《全国计算机等级考试二级C 语言真题.docx(20页珍藏版)》请在冰豆网上搜索。
全国计算机等级考试二级C语言真题
2006年9月全国计算机等级考试笔试试卷
二级公共基础知识和C语言程序设计
(考试时间120分钟,满分100分)
一、选择题(
(1)-(10)每小题2分,(11)-(50)每小题1分,共60分)
(1)下列选项中不符合良好程序设计风格的是()。
A)源程序要文档化B)数据说明的次序要规范化
C)避免滥用goto语句D)模块设计要保证高耦合、高内聚
(2)从工程管理角度,软件设计一般分为两步完成,它们是()。
A)概要设计与详细设计B)数据设计与接口设计C)软件结构设计与数据设计D)过程设计与数据设计
(3)下列选项中不属于软件生命周期开发阶段任务的是()。
A)软件测试B)概要设计C)软件维护D)详细设计
(4)在数据库系统中,用户所见的数据模式为()。
A)概念模式B)外模式C)内模式D)物理模式
(5)数据库设计的4个阶段是:
需求分析、概念设计、逻辑设计和()。
A)编码设计B)测试阶段
C)运行阶段D)物理设计
(6)设有如下3个关系表
下列操作中正确的是()。
A)T=R∩SB)T=R∪S
C)T=R×SD)T=R/S
(7)下列叙述中正确的是()。
A)一个算法的空间复杂度大,则其时间复杂度也必定大
B)一个算法的空间复杂度大,则其时间复杂度必定小
C)一个算法的时间复杂度大,则其空间复杂度必定小
D)上述三种说法都不对
(8)在长度为64的有序线性表中进行顺序查找,最坏情况下需要比较的次数为()。
A)63B)64C)6D)7
(9)数据库技术的根本目标是要解决数据的()。
A)存储问题B)共享问题C)安全问题D)保护问题
(10)对下列二叉树
进行中序遍历的结果是()。
A)ACBDFEGB)ACBDFGE
C)ABDCGEFD)FCADBEG
(11)下列叙述中错误的是()。
A)一个C语言程序只能实现一种算法
B)C程序可以由多个程序文件组成
C)C程序可以由一个或多个函数组成
D)一个C函数可以单独作为一个C程序文件存在
(12)下列叙述中正确的是()。
A)每个C程序文件中都必须要有一个main()函数
B)在C程序中main()函数的位置是固定的
C)C程序中所有函数之间都可以相互调用,与函数所处位置无关
D)在C程序的函数中不能定义另一个函数
(13)下列定义变量的语句中错误的是()。
A)int_int;
B)doubleint_;
C)charFor;
D)floatUS$;
(
14)若变量x、y已正确定义并赋值,下列符合C语言语法的表达式是()。
A)++x,y=x--B)x+1=y
C)x=x+10=x+yD)double(x)/10
(15)下列关于逻辑运算符两侧运算对象的叙述中正确的是()。
A)只能是整数0或1
B)只能是整数0或非0整数
C)可以是结构体类型的数据
D)可以是任意合法的表达式
(16)若有定义intx,y;并已正确给变量赋值,则下列选项中与表达式(x-y)?
(x++):
(y++)中的条件表达式(x-y)等价的是()。
A)(x-y>0)B)(x-y<0)
C)(x-y<0‖x-y>0)D)(x-y==0)
(17)有下列程序:
main()
{intx,y,z;
x=y=1;
z=x++,y++,++y;
printf("%d,%d,%d\n",x,y,z);
}
程序运行后的输出结果是()。
A)2,3,3B)2,3,2
C)2,3,1D)2,2,1
(18)设有定义:
inta;floatb;执行scanf("%2d%f",&a,&b);语句时,若从键盘输入
876543.0,a和b的值分别是()。
A)876和543.000000B)87和6.000000
C)87和543.000000D)76和543.000000
(19)有下列程序:
main()
{inta=0,b=0;
a=10;/*给a赋值
b=20;给b赋值*/
printf("a+b=%d\n",a+b);/*输出计算结果*/
}
程序运行后的输出结果是()。
A)a+b=10B)a+b=30
C)30D)出错
(20)在嵌套使用if语句时,C语言规定else总是()。
A)和之前与其具有相同缩进位置的if配对
B)和之前与其最近的if配对
C)和之前与其最近的且不带else的if配对
D)和之前的第一个if配对
(21)下列叙述中正确的是()。
A)break语句只能用于switch语句
B)在switch语句中必须使用default
C)break语句必须与switch语句中的case配对使用
D)在switch语句中,不一定使用break语句
(22)有下列程序:
main()
{intk=5;
while(--k)printf("%d",k-=3);
printf("\n");
}
执行后的输出结果是()。
A)1B)2
C)4D)死循环
(23)有下列程序:
main()
{inti;
for(i=1;i<=40;i++)
{if(i++%5==0)
if(++i%8==0)printf("%d",i);
}
printf("\n");
}
执行后的输出结果是()。
A)5B)24
C)32D)40
(24)下列选项中,值为1的表达式是()。
A)1-'0'B)1-'\0'C)'1'-0D)'\0'-'0'
(25)有下列程序:
fun(intx,inty){return(x+y);}
main()
{inta=1,b=2,c=3,sum;
sum=fun((a++,b++,a+b),c++);
printf("%d\n",sum);
}
执行后的输出结果是()。
A)6B)7
C)8D)9
(26)有下列程序:
main()
{chars[]="abcde";s+=2;printf("%d\n",s[0]);
}
执行后的结果是()。
A)输出字符a的ASCII码B)输出字符c的ASCII码
C)输出字符cD)程序出错
(27)有下列程序:
fun(intx,inty)
{staticintm=0,i=2;
i+=m+1;m=i+x+y;returnm;
}
main()
{intj=1,m=1,k;
k=fun(j,m);printf("%d,",k);
k=fun(j,m);printf("%d\n",k);
}
执行后的输出结果是()。
A)5,5B)5,11
C)11,11D)11,5
(28)有下列程序:
fun(intx)
{intp;
if(x==0‖x==1)return(3);
p=x-fun(x-2);
returnp;
}
main()
{printf("%d\n",fun(7));}
执行后的输出结果是()。
A)7B)3
C)2D)0
(29)在16位编译系统上,若有定义inta[]={10,20,30},*p=&a;,当执行p++;后,下列说法错误的是()。
A)p向高地址移了一个字节B)p向高地址移了一个存储单元
C)p向高地址移了两个字节D)p与a+1等价
(30)有下列程序:
main()
{inta=1,b=3,c=5,*p;
int*p1=&a,*p2=&b,*p3=&c;
*p=*p1*(*p2);
printf("%d\n",*p);
}
执行后的输出结果是()。
A)1B)2
C)3D)4
(31)若有定义:
intw[3][5];,则下列不能正确表示该数组元素的表达式是()。
A)*(*w+3)B)*(*w+1)[4]C)*(*(*w+1))D)*(&w[0][0]+1)
(32)若有以下函数首部
intfun(doublex[10],int*n)
则下列针对此函数的函数声明语句中正确的是()。
A)intfun(doublex,int*n);B)intfun(double,int);C)intfun(double*x,intn);D)intfun(double*,int*);
(33)若有定义语句:
intk[2][3],*pk[3];,则下列语句中正确的是()。
A)pk=k;B)pk[0]=&k[1][2];
C)pk=k[0];D)pk[1]=k;
(34)有下列程序:
voidchange(intk[]){k[0]=k[5];}
main()
{intx[10]={1,2,3,4,5,6,7,8,9,10},n=0;while(n<=4){change(&x[n]);n++;}for(n=0;n<5;n++)printf("%d",x[n]);printf("\n");
}
程序运行后输出的结果是()。
A)678910B)13579
C)12345D)62345
(35)若要求定义具有10个int型元素的一维数组a,则下列定义语句中错误的是()。
A)#defineN10B)#definen5inta[N];inta[2*n];
C)inta[5+5];D)intn=10,a[n];
(36)有下列程序:
main()
{intx[3][2]={0},i;
for(i=0;i<3;i++)scanf("%d",x[i]);
printf("%3d%3d%3d\n",x[0][0],x[0][1],x[1][0]);
}
若运行时输入:
246,则输出结果为()。
A)200B)204
C)240D)246
(37)有下列程序:
main()
{chars[]={"aeiou"},*ps;
ps=s;printf("%c\n",*ps+4);
}
程序运行后的输出结果是()。
A)aB)e
C)uD)元素s[4]的地址
(38)下列语句中存在语法错误的是()。
A)charss[6][20];ss[1]="right?
";B)charss[][20]={"right?
"};
C)char*ss[6];ss[1]="right?
";D)charss[]={"right?
"};
(39)若有定义:
char*x="abcdefghi";,下列选项中正确运用了strcpy函数的是()。
A)chary[10];strcpy(y,x[4]);B)chary[10];strcpy(++y,&x[1]);
C)chary[10],*s;strcpy(s=y+5,x);D)chary[10],*s;strcpy(s=y+1,x+1);
(40)有下列程序:
intadd(inta,intb){return(a+b);}
main()
{intk,(*f)(),a=5,b=10;
f=add;
…
}
则下列函数调用语句错误的是()。
A)k=(*f)(a,b);B)k=add(a,b);
C)k=*f(a,b);D)k=f(a,b);
(41)有下列程序:
#include
main(intargc,char*argv[])
{inti=1,n=0;
while(iprintf("%d\n",n);
}该程序生成的可执行文件为:
proc.exe。
若运行时输入命令行:
proc1234567
则程序的输出结果是()。
A)3B)5
C)7D)11
(42)有下列程序:
voidfun2(chara,charb){printf("%c%c",a,b);}
chara='A',b='B';
voidfun1(){a='C';b='D';}
main()
{fun1();printf("%c%c",a,b);fun2('E','F');
}
程序的运行结果是()。
A)CDEF
B)ABEF
C)ABCD
D)CDAB
(43)有下列程序:
#include
#defineN5
#defineMN+1
#definef(x)(x*M)
main()
{inti1,i2;i1=f
(2);i2=f(1+1);
printf("%d%d\n",i1,i2);
}
程序的运行结果是()。
A)1212B)117
C)1111D)127
(44)设有以下语句:
typedefstructTT
{charc;inta[4];}CIN;
则下列叙述中正确的是()。
A)可以用TT定义结构体变量B)TT是struct类型的变量
C)可以用CIN定义结构体变量D)CIN是structTT类型的变量
(45)有下列结构体说明、变量定义和赋值语句:
structSTD
{charname[10];
intage;
charsex;
}s[5],*ps;
ps=&s[0];
则下列scanf函数调用语句中错误引用结构体变量成员的是()。
A)scanf("%s",s[0].name);
B)scanf("%d",&s[0].age);
C)scanf("%c",&(ps->sex));
D)scanf("%d",ps->age);
(46)若有下列定义和语句:
uniondata
{inti;charc;floatf;}x;
inty;
则下列语句正确的是()。
A)x=10.5;B)x.c=101;
C)y=x;D)printf("%d\n",x);
(47)程序中已构成如下图所示的不带头结点的单向链表结构,指针变量s、p、q均已正确定义,并用于指向链表结点,指针变量s总是作为头指针指向链表的第一个结点。
若有下列程序段
q=s;s=s->next;p=s;
while(p->next)p=p->next;
p->next=q;q->next=NULL;
该程序段实现的功能是()。
A)首结点成为尾结点B)尾结点成为首结点
C)删除首结点D)删除尾结点
(48)若变量已正确定义,则下列语句的输出结果是()。
s=32;s^=32;printf("%d",s);
A)-1B)0
C)1D)32
(49)下列叙述中正确的是()。
A)C语言中的文件是流式文件,因此只能顺序存取数据B)打开一个已存在的文件并进行了写操作后,原有文件中的全部数据必定被覆盖C)在一个程序中当对文件进行了写操作后,必须先关闭该文件然后再打开,才能读
到第1个数据
D)当对文件的读(写)操作完成之后,必须将它关闭,否则可能导致数据丢失
(50)有下列程序:
#include
main()
{FILE*fp;inti;
charch[]="abcd",t;fp=fopen("abc.dat","wb+");for(i=0;i<4;i++)fwrite(&ch[i],1,1,fp);fseek(fp,-2L,SEEK_END);fread(&t,1,1,fp);
fclose(fp);
printf("%c\n",t);
}
程序执行后的输出结果是()。
A)dB)cC)bD)a
二、填空题(每空2分,共40分)注意:
以命令关键字填空的必须拼写完整。
(1)下列软件系统结构图的宽度为【1】。
(2)【2】的任务是诊断和改正程序中的错误。
(3)一个关系表的行称为【3】。
(4)按“先进后出”原则组织数据的数据结构是【4】。
(5)数据结构分为线性结构和非线性结构,带链的队列属于【5】。
(6)设有定义:
floatx=123.4567;,则执行下列语句后的输出结果是【6】。
printf("%f\n",(int)(x*100+0.5)/100.0);
(7)下列程序运行后的输出结果是【7】。
main()
{intm=011,n=11;
printf("%d%d\n",++m,n++);
}
(8)下列程序运行后的输出结果是【8】。
main()
{intx,a=1,b=2,c=3,d=4;
x=(a
a:
b;x=(xx:
c;x=(d>x)?
x:
d;
printf("%d\n",x);
}
(9)有下列程序,若运行时从键盘输入:
18,11,则程序的输出结果是【9】。
main()
{inta,b;
printf("Entera,b:
");scanf("%d,%d",&a,&b);
while(a!
=b)
{while(a>b)a-=b;
while(b>a)b-=a;
}
printf("%3d%3d\n",a,b);
}
(10)下列程序的功能是:
将输入的正整数按逆序输出。
例如:
若输入135则输出531。
请填空。
#include
main()
{intn,s;
printf("Enteranumber:
");scanf("%d",&n);
printf("Output:
");
do
{s=n%10;printf("%d",s);【10】;}
while(n!
=0);
printf("\n");
}
(11)下列程序中,fun()函数的功能是计算x2-2x+6,主函数中将调用fun()函数计算:
y1=(x+8)2-2(x+8)+6y2=sin2(x)-2sin(x)+6请填空。
#include"math.h"
doublefun(doublex){return(x*x-2*x+6);}
main()
{doublex,y1,y2;
printf("Enterx:
");scanf("%lf",&x);
y1=fun(【11】);y2=fun(【12】);printf("y1=%lf,y2=%lf\n",y1,y2);
}
(12)下列程序的功能是将N行N列二维数组中每一行的元素进行排序,第0行从小到大排序,第1行从大到小排序,第2行从小到大排序,第3行从大到小排序,例如:
请填空。
#defineN4
voidsort(inta[][N])
{inti,j,k,t;
for(i=0;ifor(j=0;jfor(k=【13】;k/*判断行下标是否为偶数来确定按升序或降序来排序*/
if(【14】?
a[i][j]a[i][j]>a[i][k])
{t=a[i][j];a[i][j]=a[i][k];a[i][k]=t;
}
}
voidoutarr(inta[N][N])
{……}
main()
{intaa[N][N]={{2,3,4,1},{8,6,5,7},{11,12,10,9},{15,14,16,13}};
outarr(aa);/*以矩阵的形式输出二维数组*/
sort(aa);
outarr(aa);
}
(13)下列程序中的函数strcpy2()实现字符串两次复制,即将t所指字符串复制两次到s所指内存空间中,全并形成一个新字符串。
例如。
若t所指字符串为:
efgh,调用strcpy2后,s所指字符串为:
efghefgh。
请填空。
#include
#include
voidstrcpy2(char*s,char*t)
{char*p=t;
while(*s++=*t++);
s=【15】;
while(【16】=*p++);
}
main()
{charstr1[100]="abcd",str2[]="efgh";
strcpy2(str1,str2);printf("%s\n",str1);
}
(14)下列程序的运行结果是:
【17】。
#include
intf(inta[],intn)
{if(n>1)
returna[0]+f(a+1,n-1);
else
returna[0];
}
main()
{intaa[10]={1,2,3,4,5,6,7,8,9,10},s;
s=f(aa+2,4);printf("%d\n",s);
}
(15)下列程序由两个源程序文件:
t4.h和t4.c组成,程序编译运行的结果是:
【18】。
t4.h的源程序为:
#defineN10
#definef2(x)(x*N)
t4.c的源程序为:
#include
#defineM8
#definef(x)((x)*M)
#include"t4.h"main()
{inti,j;
i=f(1+1);j=f2(1+1);
printf("%d%d\n",i,j);
}
(16)下列程序的功能是建立一个有3个结点的单循环链表,然后求各个结点数值域data
中数据的和。
请填空。
#include
#include
structNODE{intdata;
structNODE*next;
};
main()
{structNODE*p,*q,*r;
intsum=0;
p=(structNODE*)malloc(sizeof(structNODE));q=(structNODE*)malloc(sizeof(structNODE));r=(structNODE*)