二级C语言笔试真题及答案.docx
- 文档编号:12057676
- 上传时间:2023-04-16
- 格式:DOCX
- 页数:20
- 大小:22.36KB
二级C语言笔试真题及答案.docx
《二级C语言笔试真题及答案.docx》由会员分享,可在线阅读,更多相关《二级C语言笔试真题及答案.docx(20页珍藏版)》请在冰豆网上搜索。
二级C语言笔试真题及答案
2007年9月二级C语言笔试真题及答案
(考试时间:
120分钟,满分100分)
一、选择题(
(1)-(10)每题2分,(11)-(50)每题1分.共60分))
下列各题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)由于计算机存储空间是向量式的存储结构,因此,数据的存储结构一定是线性结构
C)程序设计语言中的数组一般是顺序存储结构,因此,利用数组只能处理线线结构
D)以上三种说法都不对
(7)冒泡排序在最坏情况下的比较次数是
A)n(n+1)/2B)nlog2nC)n(n-1)/2D)n/2
(8)一棵二叉树中共有70个叶子结点与80个度为1的结点,则该二叉树中的总结点数为
A)219B)221C)229D)231
(9)下列叙述中正确的是
A)数据库系统是一个独立的系统,不需要操作系统的支持
B)数据库技术的根本目标是要解决数据的共享问题
C)数据库管理系统就是数据库系统
D)以上三种说法都不对
(10)下列叙述中正确的是
A)为了建立一个关系,首先要构造数据的逻辑关系
B)表示关系的二维表中各元组的每一个分量还可以分成若干数据项
C)一个关系的属性名表称为关系模式
D)一个关系可以包括多个二维表
(11)C语言源程序名的后缀是
A).exeB).CC).objD).cp
(12)可在C程序中用做用户标识符的一组标识符是
A)andB)DateC)HiD)case
_2007y-m-dDr.TomBigl
(13)以下选项中,合法的一组C语言数值常量是
A)028B)12.C).177D)0x8A
.5e-3OXa234c1.510,000
-0xf4.5e0Oabc3.e5
(14)以下叙述中正确的是
A)C语言程序将从源程序中第一个函数开始执行
B)可以在程序中由用户指定任意一个函数作为主函数,程序将从此开始执行
C)C语言规定必须用main作为主函数名,程序将从此开始执行,在此结束
D)main可作为用户标识符,用以命名任意一个函数作为主函数
(15)若在定义语句:
inta,b,c,*p=&c;之后,接着执行以下选项中的语句,则能正确执行的语句是
A)scanf("%d",a,b,c);B)scanf("%d%d%d",a,b,c);
C)scanf("%d",p);D)scanf("%d",&p);
(16)以下关于long、int和short类型数据占用内存大小的叙述中正确的是
A)均占4个字节B)根据数据的大小来决定所占内存的字节数
C)由用户自己定义D)由C语言编译系统决定
(17)若变量均已正确定义并赋值,以下合法的C语言赋值语句是
A)x=y==5;B)x=n%2.5;C)x+n=I;D)x=5=4+1;
(18)有以下程序段
intj;floaty;charname[50];
scanf("%2d%f%s",&j,&y,name);
当执行上述程序段,从键盘上输入555667777abc后,y的值为
A)55566.0B)566.0C)7777.0D)566777.0
(19)若变量已正确定义,有以下程序段
i=0;
doprintf("%d,",i);while(i++);
printf("%d\n",i)
其输出结果是
A)0,0B)0,1C)1,1D)程序进入无限循环
(20)有以下计算公式
若程序前面已在命令中包含math.h文件,不能够正确计算上述公式的程序段是
A)if(x>=0)y=sqrt(x);B)y=sqrt(x)
elsey=sqrt(-x);if(x<0)y=sqrt(-x);
C)if(x>=0)y=sqrt(x);D)y=sqrt(x>=0?
x:
-x);
If(x<0)y=sqrt(-x);
(21)设有条件表达式:
(EXP)?
i++;j--,则以下表达式中(EXP)完全等价的是
A)(EXP==0)B)(EXP!
=0)C)(EXP==1)D)(EXP!
=1)
(22)有以下程序
#include
main()
{inty=9;
for(y>0;y--)
if(y%3==0)printf("%d",--y);
}
程序的运行结果是
A)741B)963C)852D)875421
(23)已有定义:
charc;,程序前面已在命令行中包含ctype.h文件,不能用于判断c中的字符是否为大写字母的表达式是
A)isupper(c)B)’A’<=c<=’Z’
C)’A’<=c&&c<=’Z’D)c<=(‘2’-32)&&(‘a’-32)<=c
(24)有以下程序
#include
main()
{inti,j,m=55;
for(i=1;i<=3;i++)
for(j=3;j<=i;j++)m=m%j;
printf("%d\n",m);
}
程序的运行结果是
A)0B)1C)2D)3
(25)若函数调用时的实参为变量时,以下关于函数形参和实参的叙述中正确的是
A)函数的实参和其对应的形参共占同一存储单元
B)形参只是形式上的存在,不占用具体存储单元
C)同名的实参和形参占同一存储单元
D)函数的形参和实参分别占用不同的存储单元
(26)已知字符’A’的ASCⅡ代码值是65,字符变量c1的值是’A’,c2的值是’D’。
执行语句printf("%d,%d",c1,c2-2);后,输出结果是
A)A,BB)A,68C)65,66D)65,68
(27)以下叙述中错误的是
A)改变函数形参的值,不会改变对应实参的值
B)函数可以返回地址值
C)可以给指针变量赋一个整数作为地址值
D)当在程序的开头包含文件stdio.h时,可以给指针变量赋NULL
(28)以下正确的字符串常量是
A)"\\\"B)’abc’C)OlympicGamesD)""
(29)设有定义:
charp[]={’1’,’2’,’3’},*q=p;,以下不能计算出一个char型数据所占字节数的表达式是
A)sizeof(p)B)sizeof(char)C)sizeof(*q)D)sizeof(p[0])
(30)有以下函数
intaaa(char*s)
{char*t=s;
while(*t++);
t--;
return(t-s);
}
以下关于aaa函数的功能叙述正确的是
A)求字符串s的长度B)比较两个串的大小
C)将串s复制到串tD)求字符串s所占字节数
(31)若有定义语句:
inta[3][6];,按在内存中的存放顺序,a数组的第10个元素是
A)a[0][4]B)a[1][3]C)a[0][3]D)a[1][4]
(32)有以下程序
#include
voidfun(char**p)
{++p;printf("%s\n",*p);}
main()
{char*a[]={"Morning","Afternoon","Evening","Night"};
fun(a);
}
程序的运行结果是
A)AfternoonB)fternoonC)MorningD)orning
(33)若有定义语句:
inta[2][3],*p[3];,则以下语句中正确的是
A)p=a;B)p[0]=a;C)p[0]=&a[1][2];D)p[1]=&a;
(34)有以下程序
#include
voidfun(int*a,intn)/*fun函数的功能是将a所指数组元素从大到小排序*/
{intt,i,j;
for(i=0;i for(j=i+1;j if(a} main() {intc[10]={1,2,3,4,5,6,7,8,9,0},i; fun(c+4,6); for(i=0;i<10;i++)printf("%d,",c); printf("\n"); } 程序运行的结果是 A)1,2,3,4,5,6,7,8,9,0,B)0,9,8,7,6,5,1,2,3,4, C)0,9,8,7,6,5,4,3,2,1,D)1,2,3,4,9,8,7,6,5,0, (35)有以下程序 #include intfun(chars[]) {intn=0; while(*s<=’9’&&*s>=’0’){n=10*n+*s-’0’;s++;} return(n); } main() {chars[10]={’6’,’1’,’*’,’4’,’*’,’9’,’*’,’0’,’*’}; printf("%d\n",fun(s)); } 程序运行的结果是 A)9B)61490C)61D)5 (36)当用户要求输入的字符串中含有空格时,应使用的输入函数是 A)scanf()B)getchar()C)gets()D)getc() (37)以下关于字符串的叙述中正确的是 A)C语言中有字符串类型的常量和变量 B)两个字符串中的字符个数相同时才能进行字符串大小的比较 C)可以用关系运算符对字符串的大小进行比较 D)空串一定比空格打头的字符串小 (38)有以下程序: #include voidfun(char*t,char*s) { while(*t! =0)t++; while((*t++=*s++)! =0); } main() { charss[10]=”acc”,aa[10]=”bbxxyy”; fun(ss,aa); printf(“%s,%s\n”,ss,aa); } 程序运行结果是 A)accxyy,bbxxyyB)acc,bbxxyy C)accxxyy,bbxxyyD)accbbxxyy,bbxxyy (39)有以下程序 #include #include voidfun(chars[][10],intn) { chart;inti,j; for(i=0;i for(j=i+1,j /*比较字符串的首字符大小,并交换字符串的首字符*/ if(s[0])>s[j][0]{t=s[0];s[0]=s[j][0];s[j][0]=t;} } main() { charss[5][10]={“bcc”,”bbcc”,”xy”,”aaaacc””aabcc”} fun(ss,5);printf(“%s,%s\n”,ss[0],ss[4]); } 程序运行结果是 A)xy,aaaaccB)aaaacc,xy C)xcc,aabccD)acc,xabcc (40)在一个C语言源程序文件中所定义的全局变量,其作用域为: A)所在文件的全部范围B)所在程序的全部范围 C)所在函数的全部范围D)由具体定义位置和extern说明来决定范围 (41)有以下程序 #include inta=1; intf(intc) {staticinta=2; c=c+1; return(a++)+c;} main() {inti,k=0; for(i=0;i<2;i++){inta=3;k+=f(a);} k+=a; printf(“%d\n”,k); } 程序运行结果是 A)14B)15 C)16D)17 (42)有以下程序 #include voidfun(intn,int*p) {intf1,f2; if(n==1||n==2)*p=1; else {fun(n-1,&f1);fun(n-2,&f2); *p=f1+f2; } } main() {ints; fun(3,&s);printf("%d\n",s); } 程序的运行结果是 A)2B)3C)4D)5 (43)若程序中有宏定义行: #defineN100则以下叙述中正确的是 A)宏定义行中定义了标识符N的值为整数100 B)在编译程序对C源程序进行预处理时用100替换标识符N C)对C源程序进行编译时用100替换标识符N D)在运行时用100替换标识符N (44)以下关于typedef的叙述错误的是 A)用typedef可以增加新类型 B)typedef只是将已存在的类型用一个新的名字来代表 C)用typedef可以为各种类型说明一个新名,但不能用来为变量说明一个新名 D)用typedef为类型说明一个新名,通常可以增加程序的可读性 (45)有以下程序 #include structtt {intx;structtt*y;}*p; structtta[4]={20,a+1,15,a+2,30,a+3,17,a}; main() {inti; p=a; for(i=1;i<=2;i++){printf("%d,",p->x);p=p->y;} } 程序的运行结果是 A)20,30,B)30,17C)15,30,D)20,15, (46)有以下程序 #include #include typedefstruct{charname[9];charsex;floatscore[2];}STU; STUf(STUa) {STUb={"Zhao",'m',85.0,90.0};inti; strcpy(a.name,b.name); a.sex=b.sex; for(i=0;i<2;i++)a.score=b.score; returna; } main() {STUc={"Qian",'f',95.0,92.0},d; d=f(c);printf("%s,%c,%2.0f,%2.0f\n",d.name,d.sex,d.score[0],d.score[1]); } 程序的运行结果是 A)Qian,f,95,92B)Qian,m,85,90C)Zhao,m,85,90D)Zhao,f,95,92 (47)设有以下定义 uniondata {intd1;floatd2;}demo; 则下面叙述中错误的是 A)变量demo与成员d2所占的内存字节数相同 B)变量demo中各成员的地址相同 C)变量demo和各成员的地址相同 D)若给demo.d1赋99后,demo.d2中的值是99.0 (48)有以下程序 #include main() {inta=1,b=2,c=3,x; x=(a^b)&c;printf("%d\n",x); } 程序的运行结果是 A)0B)1C)2D)3 (49)读取二进制文件的函数调用形式为: fread(buffer,size,count,fp);,其中buffer代表的是 A)一个文件指针,指向待读取的文件 B)一个整型变量,代表待读取的数据的字节数 C)一个内存块的首地址,代表读入数据存放的地址 D)一个内存块的字节数 (50)有以下程序 #include main() {FILE*fp;inta[10]={1,2,3,0,0},i; fp=fopen("d2.dat,"wb"); fwrite(a,sizeof(int),5,fp); fwrite(a,sizeof(int),5,fp); fclose(fp); fp=fopen("d2.dat","rb"); fread(a,sizeof(int),10,fp); fclose(fp); for(i=0;i<10;i++)printf("%d",a); } 程序的运行结果是 A)1,2,3,0,0,0,0,0,0,0,B)1,2,3,1,2,3,0,0,0,0, C)123,0,0,0,0,123,0,0,0,0,D)1,2,3,0,0,1,2,3,0,0, 二、填空题(每空2分,共40分) 请将每一个空的正确答案写在答题卡[1]至[20]序号的横线上,答在试卷上不得分. (1)软件需求规格说明书应具有完整性、无歧义性、正确性、可验证性、可修改性等特性,其中最重要的_[1]_______. (2)在两种基本测试方法中,_[2]_______测试的原则之一是保证所测模块中每一个独立路径至少要执行一次. (3)线性表的存储结构主要分为顺序存储结构和链式存储结构.队列是一种特殊的线性表,循环队列是队列的_[3]_______存储结构. (4)对下列二叉树进行中序遍历的结果为_[4]_______ F /\ CE /\\ ADG //\ BHP (5)在E-R图中距形表示_[5]_______ (6)执行以下程序时输入1234567,则输出结果是_[6]_______. #include main() {inta=1,b; scanf("%2d%2d",&a&b);printf("%d%d\n",a,b); } (7)以下程序的功能是: 输出a、b、c三个变量中的最小值.请填空。 #include main() {inta,b,c,t1,t2; scanf("%d%d%d",&a,&b,&c); t1=a t2=c printf("%d\n",t2); } (8)以下程序的输出结果是_[9]_______. #include main() {intn=12345,d; while(n! =0){d=n%10;printf("%d",d);n/=10;} } (9)有以下程序段,且变量已正确定义和赋值 for(s=1.0,k=1;k<=n;k++)s=s+1.0/(k*(k+1)); printf("s=%f\n\n",s); 请填空,使下面程序段的功能为完全相同 s=1.0;k=1; while(_[10]_______){s=s+1.0/(k*(k+1));_[11]_______;} printf("s=%f\n\n",s); (10)以下程序的输出结果是_[12]_______. #include main() {inti; for(i='a';i<'f';i++,i++)printf("%c",i-'a'+'A'); printf("\n"); } (11)以下程序的输出结果是_[13]_______. #include #include char*fun(char*t) {char*p=t; return(p+strlen(t)/2); } main() {char*str="abcdefgh"; str=fun(str); puts(str); } (12)以下程序中函数f的功能是在数组x的n个数(假定n个数互不相同)中找出最大最小数,将其中最小的数与第一个数对换,把最大的数与最后一个数对换.请填空. #include viodf(intx[],intn) {intp0,p1,i,j,t,m; i=j=x[0];p0=p1=0; for(m=0;m {if(x[m]>i){i=x[m];p0=m;} elseif(x[m]} t=x[p0];x[p0]=x[n-1];x[n-1]=t; t=x[p1];x[p1]=_[14]_______;_[15]_______=t; } main() {inta[10],u; for(u=0;u<10;u++)scanf("%d",&a); f(a,10); for(u=0;u<10;u++)printf("%d",a); printf("\n"); } (13)以下程序统计从终端输入的字符中大写字母的个数,num[0]中统计字母A的个数,num[1]中统计字母B的个数,其它依次类推.用#号结束输入,请填空. #include #include main() {intnum[26]={0},i;charc; while((_[16]_______)! ='#') if(isupper(c))num[c-‘A’]+=_[17]_______; for(i=0;i<26;i++) Printf("%c: %d\n",i+'A',num); } (14)执行以下程序的输出结果是_[18]_______. #include main() {inti,n[4]={1}; for(i=1;i<=3;i++) {n=n[i-1]*2+1;printf("%d",n);} } (15)以下程序的输出结果是_[19]_______. #include #defineM5 #defineNM+M main() {intk; k=N*N*5;printf("%d\n",k); } (16)函数main()的功能是: 在带头结点的单链表中查找数据域中值最小的结点.请填空 #include structnode {intdata; structnode*next; }; intmin(structnode*first)/*指针first为链表头指针*/ {strctnode*p;intm; p=first->next;m=p->data;p=p->next; for(;p! =NULL;p=_[20]_______) if(p->datadata; returnm; } 2007年9月全国计算机等级考试二级C语言参考答案 一、选择题 1-5DBCAA6-10CCABA 11-15BABCC16-20DABBB 21-25BCBBD26-30CCDAA 31-35BACDC36-37CDDBC 42-45AABAD46-50CDDCD 二、填空题: 1、无歧义性 2、路径覆盖 3、顺序存储结构 4、ACBDFEHGP 5、实体集 6、1234 7、a: b 8、c: t1 9、54321 10、k<=n 11、k++ 12、ACE 13
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 二级 语言 笔试 答案