《历年二级C语言笔试真题及答案(共10页).doc》由会员分享,可在线阅读,更多相关《历年二级C语言笔试真题及答案(共10页).doc(10页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、精选优质文档-倾情为你奉上2009年3月二级C语言笔试真题及答案 (1)下列叙述中正确的是A)栈是“先进先出”的线性表 B)队列是“先进先出”的线性表C)循环队列是非线性结构 D)有序性表既可以采用顺序存储结构,也可以采用链式存储结构(2)支持子程序调用的数据结构是 A)栈 B)树 C)队列 D)二叉树(3)某二叉树有5个度为2的结点,则该二叉树中的叶子结点数是 A)10 B)8 C)6 D)4(4)下列排序方法中,最坏情况下比较次数最少的是A)冒泡排序 B)简单选择排序 C)直接插排序 D)堆排序(5)软件按功能可以分为:应用软件、系统软件和支撑软件(或工具软件)。下面属于应用软件的是A)编
2、译软件 B)操作系统 C)教务管理系统 D)汇编程序(6)下面叙述中错误的是A)软件测试的目的是发现错误并改正错误 B)对被调试的程序进行“错误定位”是程序调试的必要步骤C)程序调试通常也称为Debug D)软件测试应严格执行测试计划,排除测试的随意性(7)耦合性和内聚性是对模块独立性度量的两个标准。下列叙述中正确的是A)提高耦合性降低内聚性有利于提高模块的独立性 B)降低耦合性提高内聚性有利于提高模块的独立性C)耦合性是指一个模块内部各个元素间彼此结合的紧密程度 D)内聚性是指模块间互相连接的紧密程度(8)数据库应用系统中的核心问题是A)数据库设计 B)数据库系统设计 C)数据库维护 D)数
3、据库管理员培训(9)有两个关系R,S如下:RABCa32b01c21SABa3b0c2由关系R通过运算得到关系S,则所使用的运算为A)选择 B)投影 C)插入 D)连接(10)将E-R图转换为关系模式时,实体和联系都可以表示为A)属性 B)键 C)关系 D)域(11)以下选项中合法的标识符是A) 1-1 B)11 C)-11 D)1-(12)若函数中有定义语句:int k;,则A)系统将自动给k赋初值0B)这时k中值无定义C)系统将自动给k赋初值-1D)这时k中无任何值(13)以下选项中,能用作数据常量的是 A)o115 B) 0118 C)1.5e1.5 D) 115L(14)设有定义:in
4、t x=2;,以下表达式中,值不为6的是 A) x*=x+1 B) x+,2*x C)x*=(1+x) D)2*x,x+=2(15)程序段:int x=12;double y=3.; printf(“%d%8.6f”,x,y);的输出结果是A)123. B)123. C)12,3. D)123.(16)若有定义语句:double x,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)
5、以下是if语句的基本形式:if(表达式)语句其中“表达式”A)必须是逻辑表达式B)必须是关系表达式C)必须是逻辑表达式或关系表达式D)可以是任意合法的表达式(18)有以下程序#include main()int x;scanf(“%d”,&x);if(x=3); elseif(x!=10)printf(“%dn”,x); 程序运行时,输入的值在哪个范围才会有输出结果A)不等于10的整数B)大于3且不等于10的整数C)大于3或等于10的整数D)小于3的整数(19)有以下程序#includeMain() int a=1,b=2,c=3,d=0;if(a= =1 &b+= =2)if(b!=2 |
6、c-!=3)printf(“%d,%d,%dn”,a,b,c);else printf(“%d,%d,%dn”,a,b,c);else printf(“%d,%d,%dn”,a,b,c); 程序运行后的输出结果是A)1,2,3 B)1,3,2 C)1,3,3 D)3,2,1(20)以下程序中的变量已正确定义for(i=0;i4;i+,i+for(k=1;k3;k+);printf(*”); 程序段的输出结果是A)* B)* C)* D)*(21)有以下程序#includemain()char*s=(“ABC);doprintf(“%d”,*s%10);s+;while(*s); 注意,字母A的
7、ASCII码值为65。程序运行后的输出结果是A)5670 B) C)567 D)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)有以下程序#includemain() int a1,a2;char c1,c2;scanf(“%d%c%d%c”,&a1,&c1,&a2,&c2);printf(“%d,%c
8、,%d,%c”,&1,c1,a2,c2);若想通过键盘输入,使得a1的值为12,a2的是为34,c1的值为字符a,c2的值为字符b,程序输出结果是:12,a,34,b,则正确的输入格式是(以下代表空格,代表回车)A)12a34b C)12,a,34,bB)12 D)12 a a3434 bb 24)有以下程序#includeint f(int x,int y)return()y-x)*x);main()int a=3,b=4,c=5,d;d=f(f(a,b),f(a,c);printf(“%dn”,d); 程序运行后的输出结果是A)10 B)9 C)8 D)7(25)有以下程序#include
9、void fun(char*s)while(*s) if(*s%2=0)printf(“%c”,*s);s+;main() chara=“good”;fun(a);printf(“n”);注意:字母a的ASC码值为97,程序运行后的输出结果是A)d B)go C)god D)good(26)有以下程序#include void fun( int *a,int *b)int *c;c=a;a=b;b=c;main()int x=3,y-5,*P=&x,*q=&y;fun(p,q);printf(“%d,%d,”,*p,*q);fun(&x,&y);printf(“%d,%dn”,*p,*q);
10、程序运行后的输出结果是A)3,5,5,3 B)3,5,3,5 C)5,3,3,5 D)5,3,5,3(27)有以下程序#include viod f(int *p,int *q);main() int m=1,n=2,*r=&m;f(r,&n);printf(“%d,%d”,m,n);void f(int *p,int *q)p=p+1;*q=*q+1;程序运行后输出的结果是A)1,3 B)2,3 C)1,4 D)1,2(28)以下函数按每行8个输出数组中的数据void fun( int *w,int n) int i;for(i=0;in;i+)_printf(“%d”,w);printf(
11、“n”); 下划线处应填入的语句是A)if(i/8=0)print(“n”); B) if(i/8=0)continue;C) if(i%8=0)print(“n”); D) if(i%8=0)continue;(29)若有以下定义 int x10,*pt=x; 则对x数组元素的正确应用是A)*&x10 B)*(x+3) C)*(pt+10) D)pt+330)设有定义:char s81;int i=10;,以下不能将一行(不超过80个字符)带有空格的字符串真确读入的语句或语句组是A) gets(s) B)while(si+=getchar()!=”n”;s=”0”;C)scanf(“%s”,
12、s); D)doscanf(“%c”,&s);while(si+!=”n”);s=”0”;(31)有以下程序#include main() char *a =“abcd”,”ef”,”gh”,”ijk”;int I;for(i=0;i4;i+)printf(“%c”,*a); 程序运行后输出的结果是A)aegi B)dfhk C)abcd D)abcdefghijk32)以下选项中正确的语句组是A)char s;s=”BOOK!”; B) char *s;s=”BOOK!”; C)char s10;s=”BOOK!”; D) char *s;s=”BOOK!”;(33)有以下程序#includ
13、e int funint x,int y if(x=y) return(x);else returen(x+y)/2)main() int a=4,b=5,c=6;printf(“%dn”,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 int b=2;int fun(int *k) b=*k+b;return(b);main() int a10=1,2
14、,3,4,5,6,7,8,I;for(i=2;i4;i+) b=fun(&a)+b;printf(“%d”,b);printf(“n”);程序运行后输出的结果是A)10 B)8 C)10 D)10 12 10 28 16 36)有以下程序#include #define PT 3.5;#define S(x) PT*x*x;mian() int a=1, b=2; printf(“%4.1fn”,S(a+b);程序运行后输出的结果是A)14.0 B)31.5 C)7.5 D)程序有错无输出结果37)有以下程序#include struct ord int x,y; dt2=1,2,3,4;ma
15、in() struct ord *p=dt;printf(“%d,”,+p-x); printf(“%dn”,+p-y);程序的运行结果是A)1,2 B)2,3 C)3,4 D)4,138)设有宏定义:#include IsDIV(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() int a=5,b=1,t;t=(a2|b); printf(
16、“%dn”,t)程序运行后的输出结果是 A)21 B)11 C)6 D)1(40)有以下程序#include main() EILE *f;f=fopen(“filea.txt”,”w”);fprintf(f,”abc”);fclose(f); 若文本文件filea.txt中原有内容为:hello,则运行以上程序后,文件filea.txt中的内容为A) helloabc B)abclo C)abc D)abchello二、填空题(每空2分,共30分)(1)假设一个长度为50的数组(数组元素的下标从0到49)作为栈的存储空间,栈底指针bottom指向栈底元素,栈顶指针top指向栈顶元素,如果bo
17、ttom=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( )cha
18、r c1,c2;scanf(“&c”,&c1);while(c190)scanf(“&c”,&c1);c2=c1+32;printf(“&c, &cn”,c1,c2); 程序运行输入65回车后,能否输出结果、结束运行(请回答能或不能)【8】。(9)以下程序运行后的输出结果是【9】#include main( )int k=1,s=0;doif(k&2)!=0)continue;s+=k;k+;while(k)10);printf(“s=&d/n”,s);(10)下列程序运行时,若输入labced12df输出结果为【10】#include main( )chara =0,ch;while(ch=
19、getchar()!=n)if(a&2!=0&(cha&ch=z) ch=ch-a+A;a+;putchar(ch);printf(“n”);(11)有以下程序,程序执行后,输出结果是【11】#include void fun (int *a)a0=a1;main()int a10=10,9,8,7,6,5,4,3,2,1,i;for(i=2;i=0;i-) fun&a;for(i=0;i10;i+) printf(“&d”,a);printf(“n”);(12)请将以下程序中的函数声明语句补充完整#include int【12】;main( )int x,y,(*p)();p=max;pri
20、ntf(“&dn”,&x,&y);Int max(int a,int b)return (ab/a:b);(13)以下程序用来判断指定文件是否能正常打开,请填空#include main( )FILE *fp;if (fp=fopen(“test.txt”,”r”)=【13】)printf(“未能打开文件!n”);elseprintf(“文件打开成功!n”);(14)下列程序的运行结果为【14】#include #include struct Aint a;char b10;doublec;voidf (structA*t);main()struct A a=(1001,”ZhangDa”,1
21、098,0);f(&a);printf(“&d,&s,&6,ifn”,a.a,a.b,a.c);void f(structA*t)strcpy(t-b,”ChangRong”);(15)以下程序把三个NODETYPE型的变量链接成一个简单的链表,并在while循环中输出链表结点数据域中的数据,请填空#include struct nodeint 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
22、.next=&c;c.next=0;p=h;while(p)printf(“&d”,p-data);【15】;2008年4月二级C语言笔试真题及答案一、 选择题(共70分) (1)程序流程图中指有箭头的线段表示的是A)图元关系 B)数据流 C)控制流 D)调用关系 (2)结构化程序设计的基本原则不包括 A)多态性 B)自顶向下 C)模块化 D)逐步求精(3)软件设计中模块划分应遵循的准则是A)低内聚低耦合 B)高内聚低耦合C)低内聚高耦合 D)高内聚高耦合 (4)在软件开发中,需求分析阶段产生的主要文档是A)可行性分析报告 B)软件需求规格说明书C)概要设计说明书 D)集成测试计划 (5)算法
23、的有穷性是指A)算法程序的运行时间是有限的 B)算法程序所处理的数据量是有限的C)算法程序的长度是有限的 D)算法只能被有限的用户使用 (6)对长度为n的线性表排序,在最坏情况下,比较次数不是n(n-1)/2的排序方法是 A)快速排序 B)冒泡排序C)直接插入排序 D)堆排序 (7)下列关于栈的叙述正确的是 A)栈按“先进先出”组织数据 B)栈按“先进后出”组织数据 C)只能在栈底插入数据 D)不能删除数据 (8)在数据库设计中,将E-R图转换成关系数据模型的过程属于C A)需求分析阶段 B)概念设计阶段 C)逻辑设计阶段 D)物理设计阶段 (9)有三个关系R、S和T如下: T B C D a
24、 0 k1 R S B C D a 0 k1 b 1 n1 B C D f 3 h2 a 0 k1 n 2 x1 有关系R和S通过运算得到关系T,则所使用的运算为A)并 B)自然连接 C)笛卡尔积 D)交 (10)设有表示学生选课的三张表,学生S(学号,姓名,性别,年龄,身份证号),课程C(课号,课名),选课SC(学号,课号,成绩),则表SC的关键字(键或码)为 A)课号,成绩 B)学号,成绩 C)学号,课号 D) 学号,姓名,成绩 (11)以下叙述中正确的是 A)C程序中的注释只能出现在程序的开始位置和语句的后面 B)C程序书写格式严格,要求一行内只能写一个语句 C)C程序书写格式自由,一个
25、语句可以写在多行上D)用C语言编写的程序只能放在一个程序文件中 (12)以下选项中不合法的标识符是 A)print B)FOR C)&a D)_00 (13)以下选项中不属于字符常量的是 A)C B)C C)xCC0 D)072 (14)设变量已正确定义并赋值,以下正确的表达式是 A)x=y*5=x+z B)int(15.8%5)C)x=y+z+5,+y D)x=25%5.0 (15)以下定义语句中正确的是 A)int a=b=0 ; B)char A=65+1,b=b; C)float a=1,*b=&a,*c=&b ; D)double a=0.0,b=1.1; (16)有以下程序段 ch
26、ar ch; int k; ch=a; k=12; printf(%c,%d,ch,ch,k); printf(k=%dn,k); 已知字符a的ASCll十进制代码为97,则执行上述程序段后输出结果是 A)因变量类型与格式描述符的类型不匹配输出无定值 B)输出项与格式描述符个数不符,输出为零值或不定值 C)a,97,12k=12 D)a,97,k=12(17)已知字母A的ASC代码值为65,若变量kk为char型,以下不能正确判断出kk中的值为大写字母的表达式是 A)kk=A&kk=Akk=a&(kk+32)=z D)isalpha(kk)&(kk=2&c=2&c=2&cb) a=b; c=a
27、; if(c!=a) c=b; printf(%d,%d,%dn,a,b,c); 其输出结果是 A)程序段有语法错 B)3,5,3 C)3,5,5 D)3,5,7 (20)有以下程序 #include main() int x=1,y=0,a=0,b=0; switch(x) case 1: switch(y) case 0: a+; break; case 1: b+; break; case 2: a+; b+; break; case 3: a+; b+; printf(“a=%d,b=%dn”,a,b); 程序的运行结果是 A)a=1,b=0 B)a=2,b=2 C)a=1,b=1 D
28、)a=2,b=1 (21)有以下程序 #include main() int x=8; for( ; x0; x-) if(x%3) printf(“%d,”,x-); continue; printf(“%d,”,-x); 程序的运行结果是 A)7,4,2 B)8,7,5,2 C)9,7,6,4 D)8,5,4,2 (22)以下不构成无限循环的语句或者语句组是 A)n=0; B)n=0; do+n;while(n=0); while(1)n+; C)n=10; D)for(n=0,i=1; ;i+) n+=i;while(n);n-; (23)有以下程序 #include main() in
29、t a =1,2,3,4,y,*p=&a3; -p; y=*p; printf(“y=%dn”,y); 程序的运行结果是 A)y=0 B)y=1 C)y=2 D)y=3 (24)以下错误的定义语句是 A)int x3=0,1,1,2,3; B)int x43=1,2,3,1,2,3,1,2,3,1,2,3; C)int x4=1,2,3,1,2,3,1,2,3,1,2,3; D)int x3=1,2,3,4; (25)设有如下程序段 char s20= “Bejing”,*p; p=s; 则执行p=s;语句后,以下叙述正确的是 A)可以用*p表示s0 B)s数组中元素的个数和p所指字符串长度相
30、等 C)s和p都是指针变量 D)数组s中的内容和指针变量p中的内容相等 (26)若有定义:int a23;,以下选项中对a数组元素正确引用的是 A)a2!1 B)a23 C)a03 D)a12 !1 (27)有定义语句:char s10;,若要从终端给s输入5个字符,错误的输入语句是 A)gets(&s0); B)scanf(“%s”,s+1); C)gets(s); D)scanf(“%s”,s1); (28)以下叙述中错误的是 A)在程序中凡是以“”开始的语句行都是预处理命令行 B)预处理命令行的最后不能以分号表示结束 C)#define MAX是合法的宏定义命令行 D)C程序对预处理命令
31、行的处理是在程序执行的过程中进行的 (29)以下结构体类型说明和变量定义中正确的是 A)typedef struct B)struct REC; int n; char c;REC; int n; char c;REC t1,t2; REC t1,t2; C)typedef struct REC ; D)structint n=0; char c=A;t1,t2; int n;char c;REC t1,t2; (30)以下叙述中错误的是 A)gets函数用于从终端读入字符串 B)getchar函数用于从磁盘文件读入字符 C)fputs函数用于把字符串输出到文件 D)fwrite函数用于以二进
32、制形式输出数据到文件 (31)有以下程序 #include main() int s12=1,2,3,4,4,3,2,1,1,1,2,3,c5=0,i; for(i=0;i12;i+) csi+; for(i=1;i5;i+) printf(“%d”,ci); printf(“n”); 程序的运行结果是 A)1 2 3 4 B)2 3 4 4 C)4 3 3 2 D )1 1 2 3 (32)有以下程序 #include void fun(int *s,int nl,int n2) int i,j,t; i=nl; j=n2; while(ij) t=si;si=sj;sj=t;i+;j-;
33、main() int a10=1,2,3,4,5,6,7,8,9,0,k; fun(a,0,3); fun(a,4,9); fun(a,0,9); for(k=0;k10;k+)printf(“%d”,ak); printf(“n”); 程序运行的结果是 A) B) C) D) (33)有以下程序 #include #include void fun(char *s ,int n) char *t; int i,j; for(i=0;in-1;i+) for(j=i+1;jstrlen(sj) t=si;si=sj;sj=t; main() char *ss=“bcc”,”bbcc”,”xy”
34、,”aaaacc”,”aabcc”; fun(ss,5); printf(“%s,%sn”,ss0,ss4); 程序的运行结果是 A)xy,aaaacc B)aaaacc,xy C)bcc,aabcc D)aabcc,bcc (34)有以下程序 #include int f(int x) int y; if(x=0|x=1) return (3); y=x*x-f(x-2); return y; main() int z; z=f(3); printf(“%dn”,z); 程序的运行结果是 A)0 B)9 C)6 D)8(35) 有以下程序 #include void fun(char *a,
35、char *b) while(*a=*) a+; while(*b=*a) b+;a+; main() char *s=”*a*b*”,t80; fun(s,t); puts(t); 程序的运行结果是 A)*a*b B) a*b C) a*b* D) ab (36) 有以程序 #include #include typedef struct char name9; char sex; float score2; STU; void f( STU a) STU b=“Zhao” ,m,85.0,90.0 ; int i; strcpy(a.name,b.name); a.sex=b.sex; f
36、or(i=0;i2;i+) a.scorei=b.scorei; main() STU c=“Qian”,p,95.0,92.0; f(c); printf(“%s,%c,%2.0f,%2.0fn”,c.name,c.sex,c.score0,c.score1); 程序的运行结果是 A)Qian,f,95,92 B) Qian,m,85,90 C) Zhao,f,95,92 D) Zhao,m,85,90 (37) 有以下程序 #include main() FILE *fp; int a10=1,2,3,i,n; fp=fopen(“dl.dat”,”w”); for(i=0;i3;i+)
37、fprintf(fp,”%d”,ai); fprintf(fp,”n”); fclose(fp); fp=fopen(“dl.dat”,”r”); fscanf(fp,”%d”,&n); fclose(fp); printf(“%dn”,n); 程序的运行结果是 A)12300 B) 123 C) 1 D) 321 (38)变量a中的数据用二进制表示的形式是,变量b中的数据用二进制表示的形式是。若要求将a的高4位取反,低4位不变,所要执行的运算是 A)ab B)a|b C)a&b D)a4 (39)在C语言中,只有在使用时才占用内存单元的变量,其存储类型是 A)auto和register B)
38、extern和register C) auto和static D) static和register (40)设有定义语句int(*f)(int);,则以下叙述正确的是 A)f是基类型为int的指针变量 B) f是指向函数的指针变量,该函数具有一个int类型的形参 C) f是指向int类型一维数组的指针变量 D) f是函数名,该函数的返回值是基类型为int类型的地址 二、填空题(每空2分,共30分) 请将每一个空的正确答案些在答题卡【1】至【15】序号的横线上,答在试卷上不得分。 (1)测试用例包括输入值集和【1】值集。(2)深度为5的满二叉树有【2】个叶子结点。 (3)设某循环队列的容量为50
39、,头指针front=5(指向队头元素的前一位置),尾指针rear=29(指向队尾元素),则该循环队列中共有【3】个元素。 (4)在关系数据库中,用来表示实体之间联系的是【4】。 (5) 在数据库管理系统提供的数据定义语言、数据操纵语言和数据控制语言中,【5】负责数据的模式定义与数据的物理存取构建。 (6)已有定义:char c= ;int a=1,b;(此处c的初值为空格字符),执行b=!c&a;后b的值为【6】。 (7)设变量已正确定义为整型,则表达式n=i=2,+i,i+的值为【7】。 (8)若有定义:int k;,以下程序段的输出结果是【8】。 for(k=2;k6;k+,k+) pri
40、ntf(“#%d”,k); (9)以下程序段的定义语句中,x1的初值是【9】,程序运行后输出的内容是【10】。 #include main() int x=1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,*p4,i; for(i=0;i4;i+) pi=&x2*i+1; printf(“%d ”,pi0); printf(“n”); (10)以下程序的输出结果是【11】。 #include void swap(int *a,int *b) int *t; t=a; a=b; b=t; main() int i=3,j=5,*p=&i,*q=&j; swap(p,q
41、); printf(“%d %dn”,*p,*q); (11)以下程序的输出结果是【12】。 #include main() int a5=2,4,6,8,10, *p; p=a; p+; printf(“%d”,*p); (12)以下程序的输出结果是【13】。 #include void fun(int x) if(x/20) fun(x/2); printf(“%d ”,x); main() fun(3); printf(“n”); (13)以下程序中函数fun的功能是:统计person所指结构体数组中所有性别(sex)为M的记录的个数,存入变量n中,并做为函数值返回。请填空: #include #define N 3 typedef struct int