计算机等级考试二级C语言习题解析.docx
- 文档编号:30472780
- 上传时间:2023-08-15
- 格式:DOCX
- 页数:22
- 大小:51.54KB
计算机等级考试二级C语言习题解析.docx
《计算机等级考试二级C语言习题解析.docx》由会员分享,可在线阅读,更多相关《计算机等级考试二级C语言习题解析.docx(22页珍藏版)》请在冰豆网上搜索。
计算机等级考试二级C语言习题解析
2010年3月全国计算机等级考试二级C语言笔试试题及答案
一、选择题下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的,请将正确的选项涂写在答题卡相应位置上,答在试卷上不得分。
(1)下列叙述中正确的是
A)对长度为n的有序链表进行查找,最坏清况下需要的比较次数为n
当有序链表为顺序存储时才能采用二分查找,二分查找需比较log2n次,而顺序查找需比较n次。
线性表一般分为顺序存储和链式存储两种。
只有对于像数组这样的顺序存储的线性表,才可以使用对分查找;链表如果只能通过p->next或者p->pre的方式来进行顺序遍历。
所以,对于长度为n的有序链表进行查找,只有一种方法:
顺序遍历,因此最坏情况为n.
B)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(n/2)
C)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(log2n)
D)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(nlog2n)
(2)算法的时问复杂度是指
A)算法的执行时间
B)算法所处理的数据量
C)算法程序中的语司或指令条数
D)算法在执行过程中所需要的基本运算次数
(3)软件按功能可以分为:
应用软件、系统软件和支撑软件(或工具软件)。
下面属于系统软件的是
A)编辑软件B)操作系统C)教务管理系统D)浏览器2009年3月5题。
编辑软件应该是应用软件。
好象只有操作系统、数据库还有一两个,记不清了,其它的都是应用软件。
(4)软件(程序)调试的任务是
A)诊断和改正程序中的错误
B)尽可能多地发现程序中的错误
C)发现并改正程序中的所有错误
D)确定程序中错误的性质
(5)数据流程图(DFD图)是
A)软件概要设计的工具
B)软件详细设计的工具
C)结构化方法的需求分析工具
D)面向对象方法的需求分析工具
(6)软件生命周期可分为定义阶段,开发阶段和维护阶段。
详细设计属于
A)定义阶段B)开发阶段C)维护阶段D)上述三个阶段
(7)数据库管理系统中负责数据模式定义的语言是
A)数据定义语言
B)数据管理语言
C)数据操纵语言
D)数据控制语言
数据定义语言:
负责数据的模式定义与数据的物理存取构建;
数据操纵语言:
负责数据的操纵,如查询与增、删、改等;
数据控制语言:
负责数据完整性、安全性的定义与检查以及并发控制、故障恢复等。
(8)在学生管理的关系数据库中,存取一个学生信息的数据单位是
A)文件B)数据库C)字段D)记录
(9)数据库设计中,用E-R图来描述信息结构但不涉及信息在计算机中的表示,它属于数据库设计的
A)需求分析阶段B)逻辑设计一阶段
C)概念设计阶段D)物理设计阶段
数据库设计分为四个阶段:
1),需求分析阶段:
编写软件规格说明书及初步的用户手册,提交评审。
2),概念设计(概要设计)阶段:
E-R图设计阶段。
3),逻辑设计阶段:
主要是E_R转换成关系模式。
4),物理设计阶段。
(10)有两个关系R和T如下:
则由关系K得到关系T的操作是
A)选择B)投影
C)交 D)并
选择运算是从一个关系中选取满足条件的元组(行)组成一个新关系
投影运算是在给定的关系中指定若干属性(列)组成一个新关系
(11)以下叙述正确的是
A)C语言程序是由过程和函数组成的
B)C语言函数可以嵌套调用,例如:
fun(fun(x))
C)C语言函数不可以单独编译
D)C语言中除了main函数,其他函数不可作为单独文件形式存在
(12)以下关于C语言的叙述中正确的是
A)C语言中的注释不可以夹在变量名或关键字的中间
B)C语言中的变量可以在使用之前的任何位置进行定义
C)在C语言算术表达式的书写中,运算符两侧的运算数类型必须一致
D)C语言的数值常量中夹带空格不影响常量值的正确表示
(13)以下C语言用户标识符中,不合法的是
A)_1
B)AaBc
C)a_b
D)a—b
(14)若有定义:
doublea=22;inti=0,k=18;,则不符合C语言规定的赋值语句是
A)a=a++,i++;
B)i=(a+k)<=(i+k);<=运算符优先级比=高先执行(a+k)<=(i+k)比较的结果是false,即0然后将0赋给i
C)i=a;
D)i=!
a;
因为取余运算符(%)是对整形变量(或常量)取余数,而你的变量a是double型的,所以编译肯定会报错的。
而我们知道整形可以被自动转换为float或者double,但是反过来是不行的,所以你要是想用上面的语句的话,需要加强制类型转换,即:
i=(int)a%11.
(15)有以下程序
#include
main()
{chara,b,c,d;
scanf(“%c%c”,&a,&b);
c=getchar();d=getchar();
printf(“%c%c%c%c\n”,a,b,c,d);}
当执行程序时,按下列方式输入数据(从第1列开始,代表回车,注意:
回车也是一个字符)
12
34
则输出结果是
A)1234
B)12
C)12
3
D)12
34
(16)以i关于C语言数据类型使用的叙述中错误的是
A)若要准确无误差的表示自然数,应使用整数类型
B)若要保存带有多位小数的数据,应使用双精度类型
C)若要处理如“人员信息”等含有不同类型的相关数据,应自定义结构体类型
D)若只处理“真”和“假”两种逻辑值,应使用逻辑类型
布尔型,因为布尔型就是只有true和false即真和假两种逻辑值,你所说的逻辑类型应该是bool布尔型吧,这个是只有真假2种情况的.
(17)若a是数值类型,则逻辑表达式(a==1)||(a!
=1)的值是
A)1
B)0
C)2
D)不知道a的值,不能确定
a是数值,则有两种情况,第一种情况:
a等于1;第二种情况:
a不等于1
现在来看这个“(a==1)”表达式:
对于第一种情况:
true,对于第二种情况:
false
接着来看“(a!
=1)”这个表达式,对于第一种情况:
false,对于第二种情况:
true
因此无论如何,(a==1)||(a!
=1)都等价于true||false其结果当然是true
(18)以下选项中与if(a==1)a=b;elsea++;语句功能不同的switch语句是
A)switch(a)
{case:
a=b;break;
default:
a++;}
B)switch(a==1)
{case0:
a=b;break;
case1:
a++;
}
C)switch(a)
{default:
a++;break;
case1:
a=b;
}
D)switch(a==1)
{case1:
a=b;break;
case0:
a++;}
(19)有如下嵌套的if语句
if(a if(a
elsek=c;
else
if(b
elsek=c;
以下选项中与上述if语句等价的语句是
A)k=(a B: C; B)k=(a ((Bc)? b: c); C)k=(a ((A A: E): ((B B: C); D)k=(a A: C; (20)有以下程序 #include main() {ini,j,m=1; for(i=1;i<3;i++) {for(j=3;j>O;j--) {if(i*j)>3)break; m*=i*j; }} printf("m=%d\n",m);} 程序运行后的输出结果是 A)m=6 B)m=2 C)m=4 D)m=5 break语句是不是使程序连外循环也跳出了。 因为在你的程序中,当i=1,j=3时,i*j=3<3。 3大于3为假所以if不执行。 所以m=m*i*j=3内层循环继续 当i=1,j=2时,i*j=2<3,if不执行。 m=m*i*j=6内层循环继续 当i=1,j=1时,i*j=1<3,m=m*i*j=6内层循环结束,然后继续外层循环,此时i自增1为2,进入内层循环 当i=2,j=3时,i*j=6>3break,跳出内层循环,然后继续外层循环,此时i自增1为3不满足循环条件,循环结束,所以最后m=6 break只跳出内层循环,不会干涉外层循环。 (21)有以下程序 #include(stdio.h> main() {inta=l;b=2; for(;a<8;a++){b+=a;a+=2;} printf("%d,%d\n",a,b);} 程序运行后的输出结果是 A)9,18 B)8,11 C)7,11 D)10,14 (22)有以下程序,其中k的初值为八进制数 #include main() {intk=011; printf("%d\n",k++);} 程序运行后的输出结果是 A)12B)11C)10D)9 (23)下列语句组中,正确的是 A)char*s;s="Olympic"; B)chars[7];s="Olympic"; C)char*s;s={"Olympic"}; D)chars[7];s={"Olympic"}; (24)以下关于return语句的叙述中正确的是 A)一个自定义函数中必须有一条return语句 B)一个自定义函数中可以根据不同情况设置多条return语句 C)定义成void类型的函数中可以有带返回值的return语句 D)没有return语句的自定义函数在执行结束时不能返回到调用处 (25)下列选项中,能正确定义数组的语句是 A)intnum[0..2008];B)intnum[]; C)intN=2008;intnum[N];D)#defineN2008;intnum[N]; (26)有以下程序 #include voidfun(char*c,intd) {*c=*c+1;d=d+1; printf("%c,%c,",*c,d); main() {charb='a',a='A'; fun(&b,a);printf("%e,%e\n",b,a);} 程序运行后的输出结果是 A)b,B,b,A B)b,B,B,A C)a,B,B,a D)a,B,a,B (27)若有定义int(*Pt)[3];,则下列说法正确的是 A)定义了基类型为int的三个指针变量 B)定义了基类型为int的具有三个元素的指针数组pt C)定义了一个名为*pt、具有三个元素的整型数组 D)定义了一个名为pt的指针变量,它可以指向每行有三个整数元素的二维数组 (28)设有定义doublea[10],*s=a;,以下能够代表数组元素a[3]的是 A)(*s)[3] B)*(s+3) C)*s[3] D)*s+3 s=a,s是个一级指针,那么*(s+3)=s[3],至于*s[3]和(*s)[3]都是语法错误的 如果定义double(*s)[3]那么s是个数组指针,是个二级指针 如果定义double*s[3]那么s是个指针数组,也是个二级指针 (29)有以下程序 #include(stdio.h) main() {inta[5]={1,2,3,4,5},b[5]={O,2,1,3,0},i,s=0; for(i=0;i<5;i++)s=s+a[b[i]]); printf("%d\n",s); } 程序运行后的输出结果是 A)6 B)10 C)11 D)15 (30)有以下程序 #include main() {intb[3][3]={O,1,2,0,1,2,O,1,2},i,j,t=1; for(i=0;i<3;i++) for(j=ij<=1;j++)t+=b[i][b[j][i]]; printf("%d\n",t); } 观察b[3][3]: 012012012可以发现b[j][i]=i。 不管你j怎么变化,i都是从0-2的变化.所以t+=b[i][b[j][i]]就是t+=b[i][i],也就是t+=i。 分析循环条件可得: 当i=0时,t=1,i=1时,t=1+b[1][1]=1+1=2,i=2时,t=2+2=4. 程序运行后的输出结果是 A)1 B)3 C)4 D)9 (31)若有以下定义和语句 chars1[10]="abcd! ",*s2="\n123\\"; printf("%d%d\n",strlen(s1),strlen(s2)); 则输出结果是 A)55 B)105 C)107 D)58 (32)有以下程序 #include #defineN8 voidfun(int*x,inti) {*x=*(x+i);} main() {inta[N]={1,2,3,4,5,6,7,8},i; fun(a,2); for(i=O;i<> {printf("%d",a[i]);} printf("\n");} 程序运行后的输出结果是 A)1313 B)2234 C)3234 D)1234 (33)有以下程序 #include intf(intt[],intn); main {inta[4]={1,2,3,4},s; s=f(a,4);printf("%d\n",s);} intf(intt[],intn) {if(n>0)returnt[n-1]+f(t,n-1); elsereturn0;} 程序运行后的输出结果是 A)4 B)1O C)14 D)6 (34)有以下程序 #include intfun() {staticintx=1; x*2;returnx; } main() {inti,s=1, for(i=1;i<=2;i++)s=fun(); printf("%d\n",s); } 程序运行后的输出结果是 A)OB)1C)4D)8 (35)有以下程序 #include #defineSUB(a)(a)-(a) main() {inta=2,b=3,c=5,d; d=SUB(a+b)*c; printf("%d\n",d);} 程序运行后的输出结果是 d=SUB(a+b)*c;-->d=(a+b)-(a+b)*cd=(2+3)-(2+3)*5=-20 #defineSUB(a)(a)-(a)正确写法: #defineSUB(a)((a)-(a)) A)0 B)-12 C)-20 D)10 来源: 考试大-(36)设有定义: structcomplex {intreal,unreal;}data1={1,8},data2; 则以下赋值语句中错误的是 A)data2=data1; B)data2=(2,6); C)data2.real=data1.real; D)data2.real=data1.unreal; (37)有以下程序 #include#includestructA {inta;charb[10];doublec;}; voidf(structAt); main() {structAa={1001,"ZhangDa",1098.0}; f(a);printf("%d,%s,%6.1f\n",a.a,a.b,a.c); }voidf(structAt)是值传递。 {t.a=1002;strcpy(t.b,"ChangRong");t.c=1202.0;} 程序运行后的输出结果是 F()函数执行的时候,a的值传给t,t被赋值,但是a没变。 所以还是输出1001,ZhangDa,1098.0可以用指针解决 A)1001,zhangDa,1098.0 B)1002,changRong,1202.0 C)1001,ehangRong,1098.O D)1002,ZhangDa,1202.0 (38)有以下定义和语句 structworkers {intnum;charname[20];charc; struct {intday;intmonth;intyear;}s; }; structworkersw,*pw;pw=&w; 能给w中year成员赋1980的语句是 A)*pw.year=198O; B)w.year=1980; C)pw->year=1980; D)w.s.year=1980; (39)有以下程序 #include main() {inta=2,b=2,c=2; printf("%d\n",a/b&c);} 程序运行后的输出结果是 A)OB)1C)2D)3 在这里要注意的是&不是&&符号,&是位运算符吧。 因为a/b=1即转化为二进制应该是01,而c=2转换为2进制为10所以01&10对应位上都为1才为1所以00也就是输出0 (40)有以下程序 #include main() {FILE*fp;charstr[10]; fp=fopen("myfile.dat","w"); fputs("abc",fp);fclose(fp); fpfopen("myfile.data","a++"); fprintf(fp,"%d",28); rewind(fp); fscanf(fp,"%s",str);puts(str); fclose(fp); } 程序运行后的输出结果是 A)abc B)28c C)abc28 D)因类型不一致而出错 二、填空题 (1)一个队列的初始状态为空。 现将元素A,B,C,D,E,F,5,4,3,2,1依次入队,然后再依次退队,则元素退队的顺序为【1】。 队: 先进先出。 栈: 先进后出。 (2)设某循环队列的容量为50,如果头指针front=45(指向队头元素的前一位置),尾指针rear=10(指向队尾元素),则该循环队列中共有【2】15个元素。 队列头指针为front,队列尾指针为rear,队列容量为M,则元素个数为|rear-front+M|%M,注意,这个%是求余运算。 因此此题元素个数为: (10-45+50)%50=15个 (3)设二叉树如下: 对该二叉树进行后序遍历的结果为EDBGHFCA。 后序遍历指在访问根结点、遍历左子树与遍历右子树三者中,首先遍历左子树,然后遍历右子树,最后遍历访问根结点,在遍历左、右子树时,仍然先遍历左子树,然后遍历右子树,最后遍历根结点。 例如: 后序的顺序: 左->右->根后序: J,F,K,G,D,B,H,L,M,I,E,C,A后序遍历就是(A左子树)(A右子树)A a的左子树: b。 b左d。 d右边e。 a右边c。 c右边f。 f左边 g.f右边h。 edbgfhca。 左子树才到右子树才到根。 因此。 ghf (4)软件是程序、数据和文档的集合。 (5)有一个学生选课的关系,其中学生的关系模式为: 学生(学号,姓名,班级,年龄),课程的关系模式为: 课程(课号,课程名,学时),其中两个关系模式的键分别是学号和课号,则关系模式选课可定义为: 选课(学号,课号,成绩)。 课程是实体,它包含的属性中的主键是课号,而选课表的产生是由学生实体的主键学号和课程实体的主键课号联合起来做主键,用来唯一标识某个学生选了某一门课,从而得到相应的成绩。 学过数据库的话这个很容易明白,如果不是太理解建议你去借一本数据库相关的书籍,通过E-R图就能很容易明白实体属性及其关系了。 (6)设x为int型变量,请写出一个关系表达式【6】,用以判断x同时为3和7的倍数时,关系表达式的值为真。 (7)有以下程序 #include main() {inta=1,b=2,c=3,d=0; if(a==1) if(b! =2) if(c==3)d=1; elsed=2; elseif(c! =3)d=3; elsed=4; elsed=5;这是a不等于1的情况。 printf(“%d\n”,d);} 程序运行后的输出结果是【7】。 (8)有以下程序 #include main() {intm,n; scanf("%d%d",&m,&n); while(m! =n) {while(m>n)m=m-n; while(m } printf("%d\n",m); } 这题觉得先是输入m,n的值当m=n时直接输出m的值,当m! =n时进入while循环,当m>n时m=m-n判断此时m与n的大小关系.若m仍大于n,继续执行m=m-n,若m =n,进入while语句.执行n=n-m之后n=49,这是n还是>m继续执行n=n-m之后n=35,同上人继续n=n-m,n=21,继续执行n=n-m,n=7此时n 程序运行后,当输入1463<回车>时,输出结果是7。 (9)有以下程序 #include main() {inti,j,a[][3]={1,2,3,4,5,6,7,8,9}; for(i=0;i<3;i++) for(j=i;j<3;j++)printf(“%d%,a[i][j]); printf("\n"); } 程序运行后的输出结果是【9】。 (10)有以下程序 #includ
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机等级考试 二级 语言 习题 解析