计算机等级考试二级C语言习题解析.docx
- 文档编号:28469440
- 上传时间:2023-07-14
- 格式:DOCX
- 页数:23
- 大小:31.26KB
计算机等级考试二级C语言习题解析.docx
《计算机等级考试二级C语言习题解析.docx》由会员分享,可在线阅读,更多相关《计算机等级考试二级C语言习题解析.docx(23页珍藏版)》请在冰豆网上搜索。
计算机等级考试二级C语言习题解析
2009年3月全国计算机等级考试二级C语言笔试试题及答案
一、选择题(每题2分,共计70分)下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的,请将正确的选项涂写在答题卡相应位置上,答在试卷上不得分。
(1)程序流程图中带有箭头的线段表示的是:
A.图元关系B.数据流C.控制流D.调用关系
控制流图:
表示的是一个程序里各个模块的分类和关系。
每个在图形中的节点代表一个基本块
流程图:
说白了就是操作程序的过程和方法,是实现控制流图效果的过程中用到的所有控件的使用过程与关系。
在数据流图中,用标有名字的箭头表示数据流。
数据流可以从加工流向加工,也可以从加工流向文件或从文件流向加工,并且可以从外部实体流向系统或从系统流向外部实体。
1.下列叙述中正确的是
A)栈是先进先出的线性表
B)队列是"先进后出"的线性表
C)循环队列是非线性结构
D)有序线性表即可以采用顺序存储结构,也可以采用链式存储结构
2.支持子程序调用的数据结构是
A)栈B)树C)队列D)二叉树
函数调用的时候要入栈,返回要出栈,所以需要用到栈结构
理论上来说所有数据结构都支持子程序的调用。
这个题的意思应该是子程序调用的时候能看成什么样的数据结构。
严格来说是栈——因为递归调用子程序的时候就是先入后出的而且是线性的。
虽然子程序也可以这样调用
f[i]=f[i-1]+f[i-1]
看起来像是树,但是实际上还是深度优先遍历一棵树,本质上是个栈。
所以说这个题的题意不清。
如果说“能够使用子程序调用的数据结构”就是全选,如果是“子程序调用的时候能看成什么样的数据结构“就是栈。
)
是栈,栈是限定只在一端进行插入与删除的线性表,通常称插入、删除的这一端为栈顶,另一端为栈底。
栈顶元素总是后被插入的元素,也是最先被删除的元素;栈底元素总是最先被插入的元素,也是最后被删除的元素。
栈是按照“先进后出”或“后进先出”的原则组织数据的。
3.某二叉树有5个读为2的结点,则该二叉树中的叶子结点数是
A10B8C)6D)4
4.下列排序方法中,最坏情况下比较次数最少的是
A)冒泡排序
B)简单选择排序
C)直接插入排序
D)堆排序
最坏情况下
直接选择排序:
每次都要执行交换总移动次数为(n-1)次交换O(n)
冒泡排序:
每比较一次都要进行一次交换,移动次数为3n(n-1)/2O(n2)
直接插入排序:
n2/4O(n2)
堆排序:
O(nlog2n)
5软件按功能可以分为:
应用软件、系统软件和支撑软件(或工具软件)。
下列
属于应用软件的是
A)编译程序系统软件
B)操作系统系统软件
C)教务管理系统或者浏览器
D)汇编程序系统软件
系统软件:
系统软件是负责管理计算机系统中各种独立的硬件,使得它们可以协调工作。
系统软件使得计算机使用者和其他软件将计算机当作一个整体而不需要顾及到底层每个硬件是如何工作的。
系统软件包括操作系统和一系列基本的工具(比如编译器,数据库管理,存储器格式化,文件系统管理,用户身份验证,驱动管理,网络连接等方面的工具)。
支撑软件:
支撑软件是支撑各种软件的开发与维护的软件,又称为软件开发环境。
它主要包括环境数据库、各种接口软件和工具组。
著名的软件开发环境有IBM公司的WebSphere,微软公司的Studio.NET等。
应用软件:
应用软件是为了某种特定的用途而被开发的软件。
它可以是一个特定的程序,比如一个图像浏览器。
也可以是一组功能联系紧密,可以互相协作的程序的集合,比如微软的Office软件。
也可以是一个由众多独立程序组成的庞大的软件系统,比如数据库管理系统。
主要有:
文字处理软件如WPS、Word等教育与娱乐软件等
6.下面叙述中错误的是
A)软件测试的目的是发现错误并改正错误
B)对被调试程序进行"错误定位"是程序调试的必要步骤
C)程序调试也成为Debug
D)软件测试应严格执行测试计划,排除测试的随意性
解析:
软件测试是为了发现错误而执行程序的过程。
软件调试的目的是发现错误并改正错误。
软件测试要严格执行测试计划,排除测试的随意性。
程序调试通常也称Debug,对被调试的程序进行“错误定位”是程序调试的必要步骤。
7.耦合性和内聚性是对模块独立性度量的两个标准。
下列叙述中正确的是
A)提高耦合性降低内聚性有利于提高模块的独立性
B)降低耦合性提高内聚性有利于提高模块的独立性
C)耦合性是指一个模块内部各个元素间彼此结合的紧密程度
D)内聚性是指模块间互相连接的紧密程度
8.数据库应用系统中的核心问题是
A)数据库设计
B)数据库系统设计
C)数据库维护
D)数据库管理员培训
9有两个关系R,S如下:
由关系R通过运算得到关系S,则所使用的运算为
A)选择B)投影C)插入D)连接
10将E-R图转换为关系模式时,实体和联系都可以表示为
A)属性B)键C)关系D)域
实体与联系可以表示成关系,关系可以表示成二维表。
11.一下选项中合法的标识符是
A)1_1B)1-1C)_11D)1__
12.若函数中有定义语句:
intk;,则
A)系统将自动给k赋初值0
B)这是k中的值无定义只是声明不是定义。
C)系统将自动给k赋初值-1
D)这时k中无任何值
如果是全局变量,k的值为0.
如果是在函数内部定义的局部变量,k的值就是随机的。
就是一选择题,答案是这时的k中的值无定义。
感觉怪怪的
这说明你的k是在函数内部定义的。
局部变量的内存是从栈里分配的,系统会从栈里找到一个int那么大的内存分配给k。
因为这个栈里的东西没有清零,所以这段内存里的内容什么不知道是什么情况。
所以,局部变量使用前必须初始化。
对于c语言,intk;
只是声明变量k,至于只是变量k的数值是多少,是不可知的。
除非intk=0;
13.一下选项中,能用作数据常量的是
A)o115
B)0118
C)1.5e1.5
D)115L
A如果是0115就是一个合法的8进制常量,不过以o开头就成了变量名
B以0开头是八进制,不过八进制只能是0~7,于是错误
C的尾数是1.5正确,但是阶码为1.5错误,只能为整数
D的后缀L代表长型,115L则表示长整型,因此正确
14.设有定义:
intx=2;,一下表达式中,值不为6的是
A)x*=x+1
B)X++,2*x
C)x*=(1+x)
D)2*x,x+=2
2*x之后。
X并没有变化。
所以x=x+2=4.
15.程序段:
intx=12;doubley=3.141593;printf("%d%8.6f",x,y);的输出结果是
A)123.141593
B)123.141593
C)12,3.141593
D)123.1415930
16.若有定义语句:
doublex,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()
{intx;
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()
{inta=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);
elseprintf("%d,%d,%d\n",a,b,c);
elseprintf("%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++,j++)
for(k=1;k<3;k++);这个时候循环结束了。
于是只执行一个。
printf("*");
程序段的输出结果是
A)********
B)****
C)**
D)*
其实这是一个双重循环,但是循环语句是空的。
就是说一直循环,除了循环变量变化外,其他没有什么变化。
printf是一个单独的语句,和循环没有什么关系。
两个i++有啥用相当于i=i+2;
就是增加循环变量i的值,让其以2为步长递增。
直至循环结束。
21.有以下程序
#include
main()
{char*s={"ABC"};
do
{printf("%d",*s%10);s++;
}
while(*s);
}
注意:
字母A的ASCII码值为65。
程序运行后的输出结果是
A)5670B)656667C)567D)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()
{inta1,a2;charc1,c2;
scanf("%d%c%d%c",&a1,&c1,&a2,&c2);
printf("%d,%c,%d,%c",a1,c1,a2,c2);}
若通过键盘输入,使得a1的值为12,a2的值为34,c1的值为字符a,c2的值为字符b,
程序输出结果是:
12,a,34,b则正确的输入格式是(以下_代表空格,
A)12a34b
10A空格20B空格
10对应&a1,A对应&c1,空格不是数值,&a2无法接受,所以继续等待,20是数值,对应&a2,B对应&c2
B)12_a_34_b
10对应&a1,空格对应&c1,A对应&a2,错误,等待,空格对应&a2,错误。
C)12,a,34,b
D)12_a34_b
24.有以下程序
#include
intf(intx,inty)
{return((y-x)*x);}
main()
{inta=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
voidfun(char*s)
{while(*s)
{if(*s%2==0)printf("%c",*s);
s++;}}
main()
{chara[]={"good"};
fun(a);printf("\n");}
这个函数的功能就是显示字符串S里ASCII码是偶数的字符。
good只有d的ASCII码是偶数。
d--100g--103o--111
注意:
字母a的ASCII码值为97,程序运行后的输出结果是
A)d
B)go
C)god
D)good
26.有以下程序
#include
voidfun(int*a,int*b)
{int*c;
c=a;a=b;b=c;}
main()
{intx=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
Funa的值是x的地址b的值是y的地址记住a和b的值也是复制过来的然后你把他们的值交换了想想看和x和y的地址有什么关系呢?
你在函数中应该用intc;c=*a;*a=*b;*b=c;这样就通过地址修改了地址中的值
27.有以下程序
#include
voidf(int*p,int*q);
main()
{intm=1,n=2,*r=&m;
f(r,&n);printf("%d,%d",m,n);}
voidf(int*p,int*q)
{p=p+1;*q=*q+1;}
程序运行后的输出结果是
A)1,3
B)2,3
C)1,4
D)1,2
28.以下函数按每行8个输出数组中的数据
#include
voidfun(int*w,intn)
{inti;
for(i=0;i {____________ printf("%d",w[i]); } printf("\n");} 下划线出应填入的语句是 A)if(i/8==0)printf("\n"); B)if(i/8==0)continue; C)if(i%8==0)printf("\n"); D)if(i%8==0)continue; 29.若有以下定义 intx[10],*pt=x; 则对数组元素的正确引用是 A)*&x[10] B)*(x+3) C)*(pt+10) D)pt+3 30.设有定义: chars[81];inti=0;,以下不能将一行(不超过80个字符)带有空格的字符串正确读入的语句或语句组是 A)gets(s); B)while((s[i++]=getchar())! =~\n~);s[i]=~\0~; C)scanf("%s",s); D)do{scanf("%c",&s[i]);}while(s[i++]! =~\n~);s[i]=~\0~; 31.有以下程序 #include main() {char*a[]={"abcd","ef","gh","ijk"};inti; for(i=0;i<4;i++)printf("%c",*a[i]);} 程序运行后的输出结果是 A)aegi B)dfhk C)dfhk D)abcdefghijk 32.以下选项中正确的语句组是 A)chars[];s="BOOK! "; B)char*s;s={"BOOK! "}; C)chars[10];s="BOOK! "; D)char*s;s="BOOK! "; 33.有以下程序 #include intfun(intx,inty) {if(x==y)return(x); elsereturn((x+y)/2);} main() {inta=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 intb=2; intfun(int*k) {b=*k+b;return(b);} main() {inta[10]={1,2,3,4,5,6,7,8},i; for(i=2;i<4;i++){b=fun(&a[i])+b;printf("%d",b);} printf("\n");} 程序运行后的输出结果是 A)1012 B)810 C)1028 D)1016 36.有以下程序 #include #definePT3.5; #defineS(x)PT*x*x; main() {inta=1,b=2;printf("%4.1f\n",S(a+b));} 程序运行后的输出结果是 A)14.0 B)31.5 C)7.5 #definePT3.5就是把PT直接换成3.5然后再编译。 main(){inta=1,b=2; printf("%4.1f\n",S(a+b))S(a+b)就是PT*a+b*a+b=5.5*a+b*a+b=3.5+2+2=7.5因为a和b是变量不是常量所以不能直接相加。 如为fun(1+2)则可以fun3。 D)程序有错无输出结果 37.有以下程序 #include structord {intx,y;}dt[2]={1,2,3,4}; main() {structord*p=dt; printf("%d,",++p->x);printf("%d\n",++p->y);} 程序的运行结果是 A)1,2 B)2,3 C)3,4 D)4,1 38.设有宏定义: #defineIsDIV(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整除是否余1 D)判断m被5和7整除是否都余1 39.有以下程序 #include main() {inta=5,b=1,t; t=(a<<2)|b;printf("%d\n",t);}或运算. 程序运行后的输出结果是 A)21 B)11 C)6 D)1 40.有以下程序 #include main() {FILE*f; f=fopen("filea.txt","w"); fprintf(f,"abc"); fclose(f);} 若文本文件filea.txt中原有内容为: hello,则运行以上程序后,文件filea.txt的内容为fopen的"w"参数表示如果存在文件则长度清零,所以里面是空的,然后写入abc A)helloabc B)abclo C)abc D)abchello 二、填空题(每空2分,共30分) 请将每一个空的正确答案写在答题卡【1】~【15】序号的横线上,答在试卷上不得分。 (1)假设用一个长度为50的数组(数组元素的下标从0到49)作为栈的存储空间,栈底指针bottom指向栈底元素,栈顶指针top指向栈顶元素,如果bottom=49,top=30(数组下标),则栈中具有___19__个元素。 你可以这样想一想: 当bottom和top都等于0的时候表示是空栈,如果我们向栈中压入了一个元素,那么bottom=0,top=1;元素数=1-0=1;而不是1-0+1 如果你的栈为空栈,那么栈顶指针指向下标0,栈顶指针所指的是下一个元素要插入的位置,意思是栈顶指针的所指的下标还没有值呐。 (2)软件测试可分为白盒测试和黑盒测试。 基本路径测试属于_____测试。 (3)符合结构化原则的三种基本控制结构是: 选择结构、循环结构和_____。 (4)数据库系统的核心是__数据库管理系统___。 数据库系统的核心是数据库管理系统。 数据库管理系统的核心是数据库。 数据库系统的核心是数据库管理系统;数据库管理系统的核心是数据库。 数据库系统一般由数据库、数据库管理系统(DBMS)、应用系统、数据库管理员和用户构成。 DBMS是数据库系统的基础和核心。 (5)在E-R图中,图形包括矩形框、菱形框、椭圆框。 其中表示实体联系的是__棱形___框。 在E-R图中用菱形框代表联系. 联系是实体间的关系.联系可以分为三种: (1)一对一的联系(1: 1). (2)一对多的联系(1: n). (3)多对多的联系(m: n). 椭圆或圆角矩形表示属性.属性和实体间用无向边连接 ER图中规定: 用矩形表示实体(等同于表) 用椭圆形表示实体的属性(等同于表中字段) 用菱形表示实体关系(等同于外键),还要将有关系的实体用线连接上,线上画菱形。 平行四边形ER中没有。 6)表达式(int)((double)(5/2)+2.5)的值是___4__。 (int)((double)(5/2)+2.5) =(int)((double)2+2.5) =(int)(4.5) =4 5和2都是整型数,整型数运算,5/2的结果就是2,没有小数部分的 (7)若变量x、y已定义为int类型且X的值为99,y的值为9,请将输出语句printf(_____,x/y);补充完整,使其输出的计算结果形式为: x/y=11。 (8)有以下程序 #include main() {charc1,c2; scanf("%c",&c1); while(c1<65||c1>90)scanf("%c",&c1); c2=c1+32; printf("%c,%c\n",c1,c2);} 程序运行输入65回车后,能否输出结果、结束运行(请回答能或不能)__能__。 那么它是可以运行的,但也许不是你要的结果。 因为%c作为scanf的参数是要求录入一个字符,而65是两个字符,故实际上c1的值为'6'。 能输出结果,但不是A,a,输出的是6,v。 你把scanf("%c",&c1);中的%c改成%d就能输出A,a了 (9)以下程序运行后的输出结果是_0_。 #include main() {intk=1,s=0; do{ if((k%2)! =0)continue; s+=k;k++; }while(k>10); printf("s=%d\n",s); } 首先给你改两个关键字continue和while do之后先进入循环体,判断((k%2)! =0为真,执行continue跳出循环到while(k>10)处判断k>10为假,不再进入循环体,输出s;s仍是0 (10)下列程序运行时,若输入1abcedf2df<回车>输出结果为_1AbCeDf2Df__。 #include main() {chara=0,ch; while((ch=getchar())! ='\n') {if(a%2! =0&&(ch>='a'&&ch<='z'))ch=ch-'a'+'A';当a不是2的倍数 a++; putchar(ch);} printf("\n");} (11)有以下
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机等级考试 二级 语言 习题 解析