到的历届二级c语言考试真题.docx
《到的历届二级c语言考试真题.docx》由会员分享,可在线阅读,更多相关《到的历届二级c语言考试真题.docx(68页珍藏版)》请在冰点文库上搜索。
到的历届二级c语言考试真题
2007到2010的全国计算机考试二级c语言真题
2010年3月二级c真题及答案
试题:
一、选择题(
(1)—(10)、(21)—(40)每题2分,(11)—(20)每题1分。
共70分)
下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的,请将正确选项涂写
在答题卡上,答在试卷上不得分。
(2)算法的时间复杂度是指D
A)算法的执行时间B)算法所处理的数据量
C)算法程序中的语句或指令条数D)算法在执行过程中所需要的基本运算次数
(3)软件按功能可以分为:
应用软件、系统软件和支撑软件(或工具软件)。
下面属于系统软件的是B
A)编辑软件B)操作系统C)教务管理系统D)浏览器
(4)软件(程序)调试的任务是A
A)诊断和改正程序中的错误B)尽可能多地发现程序中的错误
C)发现并改正程序中的所有错误D)确定程序中错误的性质
(6)软件生命周期可分为定义阶段,开发阶段和维护阶段。
详细设计属于B
A)定义阶段B)开发阶段C)维护阶段D)上述三个阶段
(7)数据库管理系统中负责数据模式定义的语言是A
A)数据定义语言B)数据管理语言C)数据操纵语言D)数据控制语言
(8)在学生管理的关系数据库中,存取一个学生信息的数据单位是D
A)文件B)数据库C)字段D)记录
(11)以下叙述正确的是B
A)C语言程序是由过程和函数组成的
B)C语言函数可以嵌套调用,例如:
fun(fun(x))
C)C语言函数不可以单独编译
D)C语言中除了main函数,其他函数不可以作为单独文件形式存在
(12)以下关于C语言的叙述中正确的是B
A)C语言中的注释不可以夹在变量名或关键字的中间
B)C语言中的变量可以再使用之前的任何位置进行定义
C)在C语言算术的书写中,运算符两侧的运算数类型必须一致
D)C语言的数值常量中夹带空格不影响常量值的正确表示
(13)以下C语言用户标示符中,不合法的是D
A)_1B)AaBcC)a_bD)a--b
(14)若有定义:
doublea=22;inti=0,k=18;则不符合C语言规定的赋值语句是C
A)a=a++,i++B)i=(a+k)<=(i+k)C)i=a%11D)i=!
a
(15)
#include
Voidmain()
{
chara,b,c,d;
scanf(”%c%c”,&a,&b);
c=getchar();d=getchar();
printf(”%c%c%c%c\n”,a,b,c,d);
}
当执行程序时,按下列方式输入数据(从第一列开始,代表回车,注意:
回车是一个字符)
12
34
则输出结果是:
C
A、1234B、12C、12D、12
334
16、以下关于C语言数据类型使用的叙述中错误的是:
D
A、若要准确无误的表示自然数,应使用整数类型。
B、若要保存带有多位小数的数据,应使用双精度类型。
C、若要处理如”人员信息”等含有不同类型的相关数据,应自定义结构体类型。
D、若只处理”真”和”假”两种逻辑值,应使用逻辑类型。
17、若a是数值类型,则逻辑表达式(a==1)||(a!
=1)的值是:
A
A、1B、0C、2D、不知道a的值,不能确定
18、以下选项中与if(a==1)a=b;elsea++;语句功能不同的switch语句是:
B
A、switch(a)B、switch(a==1)
{case1:
a=b;break;{case0:
a=b;break;
default:
a++;case1:
a++;
}}
C、switch(a)D、switch(a==1)
{default:
a++;break;{case1:
a=b;break;
case1:
a=b;case0:
a++;
}}
19、有如下嵌套的if语句
if(a
if(aelsek=c;
Elseif(belsek=c;
以下选项中与上述if语句等价的语句是C
A、k=(a
a:
b;k=(bb:
c;
B、k=(a
((ba:
b):
((bb:
c);
C、k=(a
((aa:
c):
((bb:
c);
D、k=(a
a:
b;k=(aa;c
(20)有以下程序
#include
main()
{inti,j,m=1;
for(i=1;i<3;i++)
{for(j=3;j>0;j--)
{if(i*j>3)break;
m*=i*j;}}
printf(”m=%d\n”,m)}
程序运行后的输出结果是C
(A)m=6(B)m=2(C)m=4(D)m=5
(21)有以下程序
#includes
main()
{inta=1,b=2;
for(;a<8;a++){b+=a;a+=2;}
printf(”%d,%d\n”,a,b);}
程序运行后的输出结果是D
(A)9,18(B)8,11(C)7,11(D)10,14
(22)有以下程序,其中k的初值为八进制数
#include
main()
{intk=011;
printf(”%d\n”,k++);}
程序运行后的输出结果是D
(A)12(B)11(C)10(D)9
(23)下列语句中,正确的是A
A)char*s;s=”Olympic”;B)chars[7];s=”Olympic”;
C)char*s;s={”Olympic”};D)chars[7];s={”Olympic”};
(24)以下关于return语句的叙述中正确的是D
A)一个自定义函数中必须有一条return语句
B)一个自定义函数中可以根据不同情况设置多条return语句
C)定义成viod类型的函数中可以有带返回值的return语句
D)没有return语句的自定义函数在执行结束时不能返回到调用处
(25)下列选项中,能够正确定义数组的语句是D
A)intnum[0..2008];B)intnum[];
C)intN=2008;D)#defineN2008
intnum[N];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(”%c,%c\n”,b,a);}
程序运行后的输出结果是A
A)b,B,b,AB)b,B,B,AC)a,B,B,aD)a,B,a,B
(27)若有定义int(*pt)[3];,则下列说法正确的是D
A)定义了基类型为int的三个指针变量
B)定义了基类型为int的具有三个元素的指针数组pt。
C)定义了一个名为*pt、具有三个元素的整型数组
D)定义了一个名为pt的指针变量,它可以指向每行有三个整数元素的二维数组
(28)设有定义doublea[10],*s=a;,一下能够代表数组元素a[3]的是B
A)(*s)[3]B)*(s+3)C)*s[3]D)*s+3
(29)有以下程序
#include
main()
{inta[5]={1,2,3,4,5},b[5]={0,2,1,3,0},is=0
for(i=0;i<5;i++)s=s+a[b[i]];
printf("%d\n",s);}
程序运行后的输出结果是C
A)6B)10C)11D)15
30)有以下程序
#include
main()
{intb[3][3]={0,1,2,0,1,2,0,1,2},i,j,t=1;
for(i=0;i<3;i++)
For(j=i;j<=i;j++)t+=b[i][b[j][i]];
Printf("%d\n",t);}
程序运行后的输出结果是C
A)1B)3C)4D)9
(31)若有以下定义和语句A
charsl[10]="abcd!
",*s2="n123\\";
printf("%d%d\n",strlen(s1),strlen(s2));
则输出结果是
A)55B)105C)107D)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=0;i{printf("%d",a[i]);}
printf("\n");}
程序运行后的输出结果是C
A)1313B)2234C)3234D)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;}
程序运行后的输出结果是B
A)4B)10C)14D)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);
}
程序运行后的输出结果是C
A)0B)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);}
程序运行后的结果是C
A)0B)-12C)-20D)10
(39)有以下程序
#include
main()
{inta=2,b=2,c=2;
printf(”%d\n”,a/b&c);}
程序运行后的结果是C
A)0B)1C)2D)3
(40)以下程序
#include
main()
{FILE*fp;charstr[10];
fp=fopen(”myfile.dat”,”w”);
fputs(”abc”,fp);fclose(fp);
fp=fopen(”myfile.dat”,”a+”);
rewind(fp,”gd”,28);
rewind(fp);
fscanf(fp,”gs”,str);puts(str);
fclose(fp);}
程序运行后的输出结果是C
A)abcB)28cC)abc28D)因类型不一致而出错
二、填空题(每空2分,共30分)
(1)一个队列的初始状态为空,先将元素A,CB,C,D,E,F,5,4,3,2,1依次入队,然后再依次退队,则元素退队的顺序为_ABCDEF__54321__。
(4)软件是程序、数据和文档的集合。
(6)设x为int型变量,请写出一个关系表达式:
x%3==0&&x%7==0,用以判断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;
printf(”%d\n”,d);}
程序运行后的输出结果是:
4。
(8)有以下程序
#include
main()
{intm,n;
scanf(”%d%d”,&m,&n);
while(m!
=n)
{while(m>n)m=m-n;
while(mprintf(”%d\n”,m);}
程序运行后,当输入1463<回车>时,输出结果是7
(9)有以下程序
#include
main()
{intI,j,a[][3]={1,2,3,4,5,6,7,8,9};
for(i=1;i<3;i++)
for(j=I;j<3;j++)printtf(”%d”,a[i][j]);
printf(”\n”);}
程序运行后的输出结果是123569
(10)有以下程序
#include
main()
{int[]={1,2,3,4,5,6},*k[3],i=0;
while(i<3)
{
k[i]=&a[2*i];
printf(”%d”,*k[i]);
i++;}}
程序运行后的输出结果是_135__
(11)有以下程序
#include
main()
{inta[3][3]={{1,2,3},{4,5,6},{7,8,9}};
intb[3]={0},i;
for(i=0;i<3;i++)b[i]=a[i][2]+a[2][i];
for(i=0;i<3;i++)printf(”%d”,b[i]);
printf(”\n”);}
程序运行后的结果是101418_
13、以下程序的功能是:
将值为三位正整数的变量x中的数值按照个位、十位、百位的顺序拆分并输出。
请填空。
#include
main()
{intx=256;
printf(”%d-%d-%d\n”,X%10,x/10%10,x/100);}
(15)以下程序功能是:
借助指针变量找出数组元素中的最大值及其元素的下标值。
请填空。
#include
main()
{
inta[10],*p,*s;
for(p=a;p-a<10;p++)scanf(”%d”,p);
for(p=a,s=a;p-a<10;p++)if(*p>*s)s=_p_
printf(”index=%d\n”,s-a);
二、填空题(每空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
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
main( )
{int k=1,s=0;
do{
if{((k&2)!
=0)continue;
s+=k;k++;
}while(k)10);
printf(“s=&d/n”,s);
}
(10)下列程序运行时,若输入labced12df<回车> 输出结果为【10】
#include
main( )
{char a =0,ch;
while((ch=getchar())!
=’\n’)
{if(a&2!
=0&&(ch>’a’&&ch<=’z’)) ch=ch-‘a’+’A’;
a++;putchar(ch);
}
printf(“\n”);
}
(11)有以下程序,程序执行后,输出结果是【11】
#include
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
int【12】 ;
main( )
{int x,y,(*p)();
p=max;
printf(“&d\n”,&x,&y);
}
Int max(int a,int b)
{return (a>b/a:
b);}
(13)以下程序用来判断指定文件是否能正常打开,请填空
#include
main( )
{FILE *fp;
if (((fp=fopen(“test.txt”,”r”))==【13】))
printf(“未能打开文件!
\n”);
else
printf(“文件打开成功!
\n”);
(14)下列程序的运行结果为【14】
#include
#include
struct A
{int a;char b[10];double c;};
void f (struct A *t);
main()
{struct A a=(1001,”ZhangDa”,1098,0);
f(&a);printf(“&d,&s,&6,if\n”,a.a,a.b,a.c);
}
void f(struct A *t)
{strcpy(t->b,”ChangRong”); }
(15)以下程序把三个NODETYPE型的变量链接成一个简单的链表,并在while循环中输出链表结点数据域中的数据,请填空
#include
struct node
{int data; struct node *next;};
typedef struct node NODETYPE;
main()
{NODETYPE a,b,c,*h,*p;
a. data=10;b.data=20;c.data=30;h=&a;
b. next=&b;b.next=&c;c.next=’\0’;
p=h;
while(p){printf(“&d”,p->data);【15】;}
}
2009年4月二级C参考答案
选择题:
1~10:
DACDC ABABC
11~20:
CBDDA CDBCB
21~30:
CDABA BACBC
31~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
2008年9月二级C语言笔试真题及答案
(1)一个栈的初始状态为空。
现将元素1、2、3、4、5、A、B、C、D、E依次入栈,然后再依次出栈,则元素出栈的顺序是()。
A)12345ABCDEB)EDCBA54321C)ABCDE12345D)54321EDCBA
(2)下列叙述中正确的是()。
A)循环队列有队头和队尾两个指针,因此,循环队列是非线性结构
B)在循环队列中,只需要队头指针就能反映队列中元素的动态变化情况
C)在循环队列中,只需要队尾指针就能反映队列中元素的动态变化情况
D)循环队列中元素的个数是由队头指针和队尾指针共同决定
3)在长度为n的有序线性表中进行二分查找,最坏情况下需要比较的次数是()。
A)O(n)B)O(n2)C)O(log2n)D)O(nlog2n)
4)下列叙述中正确的是()。
A)顺序存储结构的存储一定是连续的,链式存储结构的存储空间不一定是连续的
B)顺序存储结构只针对线性结构,链式存储结构只针对非线性结构
C)顺序存储结构能存储有序表,链式存储结构不能存储有序表D)链式存储结构比顺序存储结构节省存储空间
5)数据流图中带有箭头的线段表示的是()。
A)控制流B)事件驱动C)模块调用D)数据流
6)在软件开发中,需求分析阶段可以使用的工具是()。
A)N-S图B)DFD图C)PAD图D)程序流程图
7)在面向对象方法中,不属于“对象”基本特点的是()。
A)一致性B)分类性C)多态性D)标识唯一性
(8)一间宿舍可住多个学生,则实体宿舍和学生之间的联系是()。
A)一对一B)一对多C)多对一D)多对多
(9)在数据管理技术发展的三个阶段中,数据共享最好的是()。
A)人工管理阶段B)文件系统阶段C)数据库系统阶段D)三个阶段相同
(10)有三个关系R、S和T如下:
RST
ABBCABC
m113m13
n235
由关系R和S通过运算得到关系T,则所使用的运算为()。
A)笛卡尔积B)交C)并D)自然连接
(11)以下叙述中正确的是()。
A)C程序的基本组成单位是语句B)C程序中的每一行只能写一条语句
C)简单C语句必须以分号结束D)C语句必须在一行内写完
12)计算机能直接执行的程序是()。
A)源程序B)目标程序C)汇编程序D)可执行程序
13)以下选项中不能作为C语言合法常量的是()。
A)'cd'B)0.1e+6C)"\a"D)'\011