全国计算机二级c语言学习知识历年真命题完整编辑版.doc
.2010年月全国计算机等级考试二级C笔试试卷 一、选择题(1) )对长度为的有序链表进行查找,最坏情况下需要的比较次数为 )对长度为的有序链表进行对分查找,最坏情况下需要的比较次数为(n/2) )对长度为的有序链表进行对分查找,最坏情况下需要的比较次数为(log2n) )对长度为的有序链表进行对分查找,最坏情况下需要的比较次数为(log2n)(2) 算法的时间复杂度是指 )算法的执行时间 )算法所处理的数据量 )算法程序中的语句或指令条数 )算法在执行过程中所需要的基本运算次数(3)软件按功能可以分为:应用软件、系统软件和支撑软件(或工具软件)。下面属于系统软件的是 )编辑软件 )操作系统 )教务管理系统 )浏览器(4)软件(程序)调试的任务是 )诊断和改正程序中的错误 )尽可能多地发现程序中的错误 )发现并改正程序中的所有错误 )确定程序中错误的性质(5)数据流程图(图)是 )软件概要设计的工具 )软件详细设计的工具 )结构化方法的需求分析工具 )面向对象方法的需求分析工具(6)软件生命周期可分为定义阶段,开发阶段和维护阶段。详细设计属于 )定义阶段 )开发阶段)维护阶段 )上述三个阶段(7)数据库管理系统中负责数据模式定义的语言是 )数据定义语言 )数据管理语言 )数据操纵语言 )数据控制语言(8)在学生管理的关系数据库中,存取一个学生信息的数据单位是 )文件 )数据库 )字段 )记录(9)数据库设计中,用图来描述信息结构但不涉及信息在计算机中的表示,它属于数据库设计的 )需求分析阶段 )逻辑设计阶段 )概念设计阶段 )物理设计阶段(10)有两个关系和如下: R T A B C a12b22c32d32 ABCc32d32则由关系得到关系的操作是)选择 )投影 )交 )并(11)以下叙述正确的是 )语言程序是由过程和函数组成的 )语言函数可以嵌套调用,例如:fun(fun() )语言函数不可以单独编译 )语言中除了main函数,其他函数不可作为单独文件形式存在(12)以下关于语言的叙述中正确的是 )语言中的注释不可以夹在变量名或关键字的中间 )语言中的变量可以在使用之前的任何位置进行定义 )在语言算术表达式的书写中,运算符两侧的运算数类型必须一致 )语言的数值常量中夹带空格不影响常量值的正确表示(13)以下语言用户标识符中,不合法的是 ) ) ) )(14)若有定义:;,;,则不符合语言规定的赋值语句是 ),; )()(); ); )!a;(15)有以下程序#includemain()char a,b,c,d; scanf(“%c%c”,&a,&b); c=getchar();d=getchar; printf(“%c%c%c%cn”,a,b,c,d);当执行程序时,按下列方式输入数据(从第列开始,代表回车,注意:回车也是一个字符)则输出结果是 ) ) ) )(16)以下关于语言数据类型使用的叙述中错误的是 )若要准确无误差的表示自然数,应使用整数类型 )若要保存带有多位小数的数据,应使用双精度类型 )若要处理如“人员信息”等含有不同类型的相关数据,应自定义结构体类型 )若只处理“真”和“假”两种逻辑值,应使用逻辑类型(17)若是数值类型,则逻辑表达式()(! )的值是 ) ) ) )不知道的值,不能确定(18)以下选项中与if(a=1)a=b;else a+;语句功能不同的switch语句是 )switch() case:;break; default:a+; )switch(a=1) case:;break; case:a+; )switch() default:a+;break; case:; )switch(a=1) case:=;break; case:a+; (19)如下嵌套的语句if(ab) if(ac) k=a; else k=c;if(bc) k=b; else k=c;以下选项中与上述语句等价的语句是 )k=(ab)?a:b;k=(bc)?b:c; )k=(ab)?(bc)?a:b)(bc)?b:c); )k=(ab)?(ac)?a:c)(bc)?b:c); )k=(ab)?a:b;k=(ac)?a:c;(20)有以下程序#includemain()int i,j,m=1; for(i=1;i0;j-)if(i+j3) break; m*=i*j;printf(“m=%dn”,m);程序运行后的输出结果是 ) ) ) )(21)有以下程序#includemain()int a=1,b=2; for(;a8;a+) b+=a;a+=2;printf(“%d,%dn”,a,b);程序运行后的输出结果是 ), ), ), ),(22)有以下程序,其中的初值为八进制数#includemain()int k=011;printf(“%dn”,k+);程序运行后的输出结果是 ) ) ) )(23)下列语句组中,正确的是 )char *s;s=Olympic; )char s7;s=Olympic; )char *s;sOlympic; )char s7;s=Olympic;(24)以下关于return语句的叙述中正确的是 )一个自定义函数中必须有一条return语句 )一个自定义函数中可以根据不同情况设置多条return语句 )定义成void类型的函数中可以有带返回值的return语句 )没有return语句的自定义函数在执行结束时不能返同到调用处(25)下列选项中,能正确定义数组的语句是 )int num0.2008; )int num; )int N=2008 ; )#define N 2008int numN; int numN;(26)有以下程序#includevoid fun(char *c,int d)*c=*c+1;d=d+1;printf(“%c,%c”,*c,d); main()char b=a,a=A;fun(&b,a);printf(“%c,%cn”,b,a);程序运行后的输出结果是 ), ), ), ),(27)若有定义int(*pt)3;,则下列说法正确的是 )定义了基类型为int的三个指针变量 )定义了基类型为int的具有三个元素的指针数组pt )定义了一个名为*pt、具有三个元素的整型数组 )定义了一个名为pt的指针变量,它可以指向每行有三个整数元素的二维数组(28)设有定义double a10,*s;,以下能够代表数组元索a3的是 )(*s)3 )*(s+3) )*s3 )*s+3(29)有以下程序#includemain()int a5=1,2,3,4,5,b5=0,2,1,3,0,i,s=0;for(i=1;i3;i+) s=s+abi;printf(“%dn”,s);程序运行后的输出结果是 ) ) ) )(30)有以下程序#includemain()int b33=0,1,2,0,1,2,0,1,2,i,j,t=1;for(i=1;i3;i+) for(j=1;j=1;j+) t+=bibji; printf(“%dn”,t);程序运行后的输出结果是 ) ) ) )(31)若有以下定义和语句char s110abcd!,s2=n123;printf(,strlen(s1),strlen(s2);则输出结果是 ) ) ) )(32)有以下程序#include#define N 8void fun(int *x,int i)*x=*x+i;main()int aN=1,2,3,4,5,6,7,8,i;fun(a,2); for(i=1;iN/2;i+)printf(“%d”,ai);printf(“n”);程序运行后的输山结果是 ) ) ) )(33)有以下程序#includeint f(int t,int n);main()int a4=1,2,3,4,s; s=f(a,4);printf(“%dn”,s);int f(int t,int n)if (n0)return tn-1+f(t,n-1);else return 0; 程序运行后的输出结果是 ) ) ) )(34)有以下程序#includeint fun()static int x=1; x*=2;return x;main()int i,s=1;for(i=1;i=2;i+) s=fun();printf(“%dn”,s);程序运行后的输出结果是 ) ) ) )(35)有以下程序#include#define SUB(a) (a)-(a)main()int a=2,b=3,c=5,d;d=SUB(a+b)*c;printf(“%dn”,d);程序运行后的输山结果是 ) ) ) )(36)设有定义:struct complexint real,unreal; data1=1,8,data2;则以下赋值语句中错误的是 )data2data1; )data2(,); )data2realdata1real; )data2realdata1unreal;(37)有以下程序#include#includestruct Aint a;char b10;double c;void f(struct At);main()struct Aa=1001,“ZhangDa”,1098.0;f(a);printf(“%d,%s,%6.1fn”,a.a,a.b,a.c); void f(struct At)t.a=1002;strcpy(t.b,“ChangRong”);t.c=1202.0;输出结果是 ), ), ), ),(38)有以下定义和语句struct workersint num;char name20;char c; struct int day;int month;int year;s;struct workers w,*pw;pw=&w;能给中year成员赋1980的语句是 ); ); ); );(39)有以下程序#includemain()int a=2,b=a,c=2;printf(“%dn”,a/b&c);程序运行后的输出结果是 ) ) ) )(40)有以下程序#includemain()FILE *fp;char str10;fp=open(“myfile.dat”,“w”);fputs(“abc”,pf);close(pf);fp=open(“myfile.dat”,“a+”);fprintf(pf,“%d”,28);rewind(pf);fscanf(pf,“%s”,str);puts(str);close(pf);程序运行后的输出结果是 ) ) ) )因类型不一致而出错二、填空题()一个队列的初始状态为空。现将元素,依次入队,然后再依次退队,则元素退队的顺序为【】。()设某循环队列的容量为50,如果头指针front45(指向队头元素的前一位置),尾指针rear10(指向队尾元素),则该循环队列中共有【】个元素。()设二叉树如下:AB C D F E G H 对该二叉树进行后序遍历的结果为【】。() 软件是【】数据和文档的集合。()有一个学生选课的关系,其中学生的关系模式为:学生(学号,姓名,班级,年龄),课程的关系模式为:课程(课号,课程名,学时),其中两个关系模式的键分别是学号和课号,则关系模式选课可定义为:选课(学号,【】,成绩)。()设为int型变量,请写出一个关系表达式【】,用以判断同时为和的倍数时,关系表达式的值为真。()有以下程序#includemain()int a=1,b=2,c=3,d=0;if(a=1) if(b!=2) if(c=3) d=1; else d=2; else if(c!=3) d=3;else d=4;else d=5;printf(“%dn”,d);程序远行后的输出结果是【】。()有以下程序#includemain()int m,n;scanf(“%d%d”,&m,&n);while(m!=n)while(mn) m=m-n; while(mn) n=n-m;printf(“%dn”,m);程序运行后,当输入14 63回车时,输出结果是【】。()有以下程序#includemain()int i,j,a3=1,2,3,4,5,6,7,8,9;for(i=1;i3;i+)for(j=1;j3;i+) printf(“%d”,aij);printf(“n”);程序运行后的输出结果是【】()有以下程序#includemain()int a=1,2,3,4,5,6,*k3,i=0; while(i3) ki=&a2*i;printf(“%d”,*ki);i+;程序运行后的输出结果是【10】。()有以下程序#includemain()int a33=1,2,3,4,5,6,7,8,9; int b3=0,i; for(i=1;i3;i+) bi=ai2+a2i;for(i=1;i3;i+)printf(“%d”,bi);printf(“n”);程序运行后的输出结果是【11】。()有以下程序#include#includevoid fun(char *str)char temp;int n,i;n=strlen(str);temp=strn-1;for(i=n-1;i0;i-) stri=stri-1;str0=temp;main()char s50;scanf(“%s”,s);fun(s);printf(“%sn”,s);程序运行后输入:abcdef回车,则输出结果是【12】()以下程序的功能是:将值为三位正整数的变量中的数值按照个位、十位、百位的顺序拆分并输出。请填空。#includemain()int x=256; printf(“%d-%d-%dn”,【13】,x/10%10,x/100);()以下程序用以删除字符串中所有的空格,请填空。#includemain()char100=“Our teacher teach c language!”;int i,j;for(i=j=0;si!=0;i+) if(si!= ) sj=si;j+;sj=【14】;printf(“%sn”,s);()以下程序的功能是:借助指针变量找出数组元素中的最大值及其元素的下标值。请填空。#includemain()int a10,*p,*s;for(p=a;p-a10;p+) scanf(“%d”,p);for(p=a,s=a;p-a*s) s=【15】;printf(“index=%dn”s-a);参考答案: 一、选择题: 1.C 2.D 3.B 4.A 5.C 6.B 7.A 8.D 9.C 10.A 11.B 12.A 13.D 14.C 15.C 16.D 17.A 18.B 19.C 20.A 21.D 22.D 23.A 24.B 25.D 26.A 27.D 28.B 29.C 30.C 31.A 32.C 33.B 34.C 35.B 36.B 37.A 38.D 39.A 40.C 二、填空题: (1)A B C D E F 5 4 3 2 1 (2)15 (3)EDBGHFCA (4)程序 (5)课号 (6)(x%3=0) & (x%7=0) (7)4 (8)7 (9)123569 (10)135 (11)101418 (12)fabcde (13)x%10 (14)0 (15)p2009年9月全国计算机等级考试二级C笔试试卷一、选择题(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-S图 B) PAD图 C) 程序流程图 D) E-R图(8)数据库管理系统是 A)操作系统的一部分 B) 在操作系统支持下的系统软件 C) 一种编译系统 D) 一种操作系统(9)在E-R图中,用来表示实体联系的图形是 A) 椭圆图 B) 矩形 C) 菱形 D) 三角形(10)有三个关系R,S和T如下:其中关系T由关系R和S通过某种操作得到,该操作为 A) 选择 B)投影 C) 交 D) 并(11)以下叙述中正确的是A)程序设计的任务就是编写程序代码并上机调试 B)程序设计的任务就是确定所用数据结构C)程序设计的任务就是确定所用算法 D)以上三种说法都不完整(12)以下选项中,能用作用户标识符的是 A)void B)8_8 C)_0_ D)unsigned(13)阅读以下程序#include main() int case; float printF; printf(“请输入2个数:”); scanf(“%d %f”,&case,&pjrintF); printf(“%d %fn”,case,printF);该程序编译时产生错误,其出错原因是 A)定义语句出错,case是关键字,不能用作用户自定义标识符 B)定义语句出错,printF不能用作用户自定义标识符 C)定义语句无错,scanf不能作为输入函数使用 D)定义语句无错,printf不能输出case的值(14)表达式:(int)(double)9/2)-(9)%2的值是 A)0 B)3 C)4 D)5 (15)若有定义语句:int x=10;,则表达式x-=x+x的值为 A)-20 B)-10 C)0 D)10(16)有以下程序#include main() int a=1,b=0; printf(“%d,”,b=a+b); printf(“%dn”,a=2*b);程序运行后的输出结果是 A)0,0 B)1,0 C)3,2 D)1,2(17)设有定义:int a=1,b=2,c=3;,以下语句中执行效果与其它三个不同的是A)if(ab) c=a,a=b,b=c; B)if(ab) c=a,a=b,b=c;C)if(ab) c=a;a=b;b=c; D)if(ab) c=a;a=b;b=c;(18)有以下程序#include main() int c=0,k; for (k=1;kb?(bc?1:0):0;功能相同的是A)if(ab)&(bc) k=1;else k=0;B)if(ab)|(bc) k=1;else k=0;C)if(a=b) k=0;else if(bb) k=1;else if(bc) k=1;else k=0;(20)有以下程序#include main() char s=“012xy”;int i,n=0; for(i=0;si!=0;i+)if(si=a&si2); printf(“%d %dn”,k,n);程序运行后的输出结果是A)0 2 B)1 3 C)5 7 D)1 2(22)有以下定义语句,编译时会出现编译错误的是A)char a=a; B)char a=n;C)char a=aa; D)char a=x2d;(23)有以下程序#include main() char c1,c2; c1=A+8-4; c2=A+8-5; printf(“%c,%dn”,c1,c2);已知字母A的ASCII码为65,程序运行后的输出结果是A)E,68 B)D,69 C)E,D D)输出无定值(24)有以下程序#include void fun(int p) int d=2; p=d+; printf(“%d”,p);main() int a=1; fun(a); printf(“%dn”,a);程序运行后的输出结果是A)32 B)12 C)21 D)22(25)以下函数findmax拟实现在数组中查找最大值并作为函数值返回,但程序中有错导致不能实现预定功能#define MIN -2147483647int findmax (int x,int n) int i,max; for(i=0;iN;I+) max=MIN;if(max return max; 造成错误的原因是A)定义语句int i,max;中max未赋初值B)赋值语句max=MIN;中,不应给max赋MIN值C)语句if(maxD)赋值语句max=MIN;放错了位置 (26)有以下程序#include main() int m=1,n=2,*p=&m,*q=&n,*r; r=p;p=q;q=r; printf(“%d,%d,%d,%dn”,m,n,*p,*q);程序运行后的输出结果是A)1,2,1,2 B)1,2,2,1 C)2,1,2,1 D)2,1,1,2(27)若有定义语句:int a410,*p,*q4;且0i4,则错误的赋值是A)p=a B)qi=ai C)p=ai D)p=&a21(28)有以下程序#include #includemain() char str 20=“One*World”, “One*Dream!”,*p=str1; printf(“%d,”,strlen(p);printf(“%sn”,p);程序运行后的输出结果是A)9,One*World B)9,One*DreamC)10,One*Dream D)10,One*World(29)有以下程序#include main() int a =2,3,5,4,i; for(i=0;i4;i+) switch(i%2) case 0:switch(ai%2) case 0:ai+;break; case 1:ai-; break;case 1:ai=0;for(i=0;i4;i+) printf(“%d”,ai); printf(“n”);A)3 3 4 4 B)2 0 5 0 C)3 0 4 0 D)0 3 0 4(30)有以下程序#include #includemain() char a10=”abcd”; printf(“%d,%dn”,strlen(a),sizeof(a);程序运行后的输出结果是A)7,4 B)4,10 C)8,8 D)10,10(31)下面是有关C语言字符数组的描述,其中错误的是A)不可以用赋值语句给字符数组名赋字符串 B)可以用输入语句把字符串整体输入给字符数组C)字符数组中的内容不一定是字符串 D)字符数组只能存放字符串(32)下列函数的功能是fun(char * a,char * b) while(*b=*a)!=0) a+,b+; A)将a所指字符串赋给b所指空间 B)使指针b指向a所指字符串C)将a所指字符串和b所指字符串进行比较 D)检查a和b所指字符串中是否有0(33)设有以下函数 void fun(int n,char * s) 则下面对函数指针的定义和赋值均是正确的是A)void (*pf)();
收藏
- 资源描述:
-
.\
2010年3月全国计算机等级考试二级C笔试试卷
一、选择题
(1) A)对长度为n的有序链表进行查找,最坏情况下需要的比较次数为n
B)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(n/2)
C)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(log2n)
D)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(log2n)
(2) 算法的时间复杂度是指
A)算法的执行时间 B)算法所处理的数据量
C)算法程序中的语句或指令条数 D)算法在执行过程中所需要的基本运算次数
(3)软件按功能可以分为:应用软件、系统软件和支撑软件(或工具软件)。下面属于系统软件的是
A)编辑软件 B)操作系统 C)教务管理系统 D)浏览器
(4)软件(程序)调试的任务是
A)诊断和改正程序中的错误 B)尽可能多地发现程序中的错误
C)发现并改正程序中的所有错误 D)确定程序中错误的性质
(5)数据流程图(DFD图)是
A)软件概要设计的工具 B)软件详细设计的工具
C)结构化方法的需求分析工具 D)面向对象方法的需求分析工具
(6)软件生命周期可分为定义阶段,开发阶段和维护阶段。详细设计属于
A)定义阶段 B)开发阶段C)维护阶段 C)上述三个阶段
(7)数据库管理系统中负责数据模式定义的语言是
A)数据定义语言 B)数据管理语言
C)数据操纵语言 D)数据控制语言
(8)在学生管理的关系数据库中,存取一个学生信息的数据单位是
A)文件 B)数据库 C)字段 D)记录
(9)数据库设计中,用E-R图来描述信息结构但不涉及信息在计算机中的表示,它属于数据库设计的
A)需求分析阶段 B)逻辑设计阶段
C)概念设计阶段 D)物理设计阶段
(10)有两个关系R和T如下:
R T
A
B
C
a
1
2
b
2
2
c
3
2
d
3
2
A
B
C
c
3
2
d
3
2
则由关系R得到关系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);
C)i=a%11; D)i=!a;
(15)有以下程序
#include
main()
{char a,b,c,d;
scanf(“%c%c”,&a,&b);
c=getchar();d=getchar;
printf(“%c%c%c%c\n”,a,b,c,d);}
当执行程序时,按下列方式输入数据(从第1列开始,<CR>代表回车,注意:回车也是
一个字符)
12<CR>
34<CR>
则输出结果是
A)1234 B)12 C)12 D)12
(16)以下关于C语言数据类型使用的叙述中错误的是
A)若要准确无误差的表示自然数,应使用整数类型
B)若要保存带有多位小数的数据,应使用双精度类型
C)若要处理如“人员信息”等含有不同类型的相关数据,应自定义结构体类型
D)若只处理“真”和“假”两种逻辑值,应使用逻辑类型
(17)若a是数值类型,则逻辑表达式(a==I)||(a! =1)的值是
A)1 B)0
C)2 D)不知道a的值,不能确定
(18)以下选项中与if(a==1)a=b;else a++;语句功能不同的switch语句是
A)switch(a)
{case1: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
main()
{int i,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);
}程序运行后的输出结果是
A)m=6 B)m=2 C)m=4 D)m=5
(21)有以下程序
#include
main()
{int a=1,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()
{int k=011;
printf(“%d\n”,k++);
}程序运行后的输出结果是
A)12 B)11 C)10 D)9
(23)下列语句组中,正确的是
A)char *s;s="Olympic"; B)char s[7];s="Olympic";
C)char *s;s={"Olympic"}; D)char s[7];s={"Olympic"};
(24)以下关于return语句的叙述中正确的是
A)一个自定义函数中必须有一条return语句
B)一个自定义函数中可以根据不同情况设置多条return语句
C)定义成void类型的函数中可以有带返回值的return语句
D)没有return语句的自定义函数在执行结束时不能返同到调用处
(25)下列选项中,能正确定义数组的语句是
A)int num[0..2008]; B)int num[];
C)int N=2008 ; D)#define N 2008
int num[N]; int num[N];
(26)有以下程序
#include
void fun(char *c,int d)
{*c=*c+1;d=d+1;
printf(“%c,%c”,*c,d);
}
main()
{char b=‘a’,a=‘A’;
fun(&b,a);printf(“%c,%c\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)设有定义double a[10],*s=a;,以下能够代表数组元索a[3]的是
A)(*s)[3] B)*(s+3)
C)*s[3] D)*s+3
(29)有以下程序
#include
main()
{int a[5]={1,2,3,4,5},b[5]={0,2,1,3,0},i,s=0;
for(i=1;i<3;i++) s=s+a[b[i]];
printf(“%d\n”,s);
}程序运行后的输出结果是
A)6 B)10 C)11 D)15
(30)有以下程序
#include
main()
{int b[3][3]={0,1,2,0,1,2,0,1,2},i,j,t=1;
for(i=1;i<3;i++)
for(j=1;j<=1;j++) t+=b[i][b[j][i]];
printf(“%d\n”,t);
}程序运行后的输出结果是
A)1 B)3 C)4 D)9
(31)若有以下定义和语句
char s1[10]="abcd!",s2="\n123\\";
printf("%d%d\n",strlen(s1),strlen(s2));
则输出结果是
A)5 5 B)10 5 C)10 7 D)5 8
(32)有以下程序
#include
#define N 8
void fun(int *x,int i)
{*x=*x+i;}
main()
{int a[N]={1,2,3,4,5,6,7,8},i;
fun(a,2); for(i=1;i
int f(int t[],int n);
main()
{int a[4]={1,2,3,4},s;
s=f(a,4);printf(“%d\n”,s);}
int f(int t[],int n)
{if (n>0)return t[n-1]+f(t,n-1);
else return 0;} 程序运行后的输出结果是
A)4 B)10 C)14 D)6
(34)有以下程序
#include
int fun()
{static int x=1;
x*=2;return x;
}
main()
{int i,s=1;
for(i=1;i<=2;i++) s=fun();
printf(“%d\n”,s);
}程序运行后的输出结果是
A)0 B)1 C)4 D)8
(35)有以下程序
#include
#define SUB(a) (a)-(a)
main()
{int a=2,b=3,c=5,d;
d=SUB(a+b)*c;
printf(“%d\n”,d);
}程序运行后的输山结果是
A)0 B)-12 C)-20 D)10
(36)设有定义:
struct complex
{int real,unreal;} data1={1,8},data2;
则以下赋值语句中错误的是
A)data2=data1; B)data2=(2,6);
C)data2.real=data1.real; D)data2.real=data1.unreal;
(37)有以下程序
#include
#include
struct A
{int a;char b[10];double c;};
void f(struct At);
main()
{struct Aa={1001,“ZhangDa”,1098.0};f(a);
printf(“%d,%s,%6.1f\n”,a.a,a.b,a.c);}
void f(struct At)
{t.a=1002;strcpy(t.b,“ChangRong”);t.c=1202.0;}
输出结果是
A)1001,ZhangDa,1098.0
B)1002,ChangRong,1202.0
C)1001,ChangRong,10980
D)1002,ZhangDa,1202.0
(38)有以下定义和语句
struct workers
{int num;char name[20];char c;
struct
{int day;int month;int year;}s
};
struct workers w,*pw;
pw=&w;
能给w中year成员赋1980的语句是
A)pw.year=1980; B)w.year=1980;
C)pw->year=1980; D)w.s.year=1980;
(39)有以下程序
#include
main()
{int a=2,b=a,c=2;
printf(“%d\n”,a/b&c);
}程序运行后的输出结果是
A)0 B)1 C)2 D)3
(40)有以下程序
#include
main()
{FILE *fp;char str[10];
fp=open(“myfile.dat”,“w”);
fputs(“abc”,pf);close(pf);
fp=open(“myfile.dat”,“a+”);
fprintf(pf,“%d”,28);
rewind(pf);
fscanf(pf,“%s”,str);puts(str);
close(pf);
}程序运行后的输出结果是
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】 个元素。
(3)设二叉树如下:
A
B C
D F
E G H
对该二叉树进行后序遍历的结果为 【3】 。
(4) 软件是 【4】 数据和文档的集合。
(5)有一个学生选课的关系,其中学生的关系模式为:学生(学号,姓名,班级,年龄),课程的关系模式为:课程(课号,课程名,学时),其中两个关系模式的键分别是学号和课号,则关系模式选课可定义为:选课(学号, 【5】 ,成绩)。
(6)设x为int型变量,请写出一个关系表达式 【6】 ,用以判断x同时为3和7的倍数时,关系表达式的值为真。
(7)有以下程序
#include
main()
{int a=1,b=2,c=3,d=0;
if(a==1)
if(b!=2)
if(c==3) d=1;
else d=2;
else if(c!=3) d=3;
else d=4;
else d=5;
printf(“%d\n”,d);
}程序远行后的输出结果是 【7】 。
(8)有以下程序
#include
main()
{int m,n;
scanf(“%d%d”,&m,&n);
while(m!=n)
{while(m>n) m=m-n;
while(m
main()
{int i,j,a[][3]={1,2,3,4,5,6,7,8,9};
for(i=1;i<3;i++)
for(j=1;j<3;i++) printf(“%d”,a[i][j]);
printf(“\n”);
}程序运行后的输出结果是 【9】
(10)有以下程序
#include
main()
{int a[]={1,2,3,4,5,6},*k[3],i=0;
while(i<3)
{k[i]=&a[2*i];
printf(“%d”,*k[i]);
i++;
}
}程序运行后的输出结果是 【10】 。
(11)有以下程序
#include
main()
{int a[3][3]={{1,2,3},{4,5,6},{7,8,9}};
int b[3]={0},i;
for(i=1;i<3;i++) b[i]=a[i][2]+a[2][i];
for(i=1;i<3;i++)printf(“%d”,b[i]);
printf(“\n”);
}程序运行后的输出结果是 【11】 。
(12)有以下程序
#include
#include
void fun(char *str)
{char temp;int n,i;
n=strlen(str);
temp=str[n-1];
for(i=n-1;i>0;i--) str[i]=str[i-1];str[0]=temp;
}
main()
{char s[50];scanf(“%s”,s);fun(s);printf(“%s\n”,s);}
程序运行后输入:abcdef<回车>,则输出结果是 【12】
(13)以下程序的功能是:将值为三位正整数的变量x中的数值按照个位、十位、百位的顺序拆分并输出。请填空。
#include
main()
{int x=256;
printf(“%d-%d-%d\n”,【13】,x/10%10,x/100);
}
(14)以下程序用以删除字符串中所有的空格,请填空。
#include
main()
{char[100]={“Our teacher teach c language!”};int i,j;
for(i=j=0;s[i]!=‘\0’;i++)
if(s[i]!=‘ ’) {s[j]=s[i];j++;}
s[j]=【14】;
printf(“%s\n”,s);
}
(15)以下程序的功能是:借助指针变量找出数组元素中的最大值及其元素的下标值。请填空。
#include
main()
{int a[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=【15】;
printf(“index=%d\n”s-a);
}
参考答案:
一、选择题:
1.C 2.D 3.B 4.A 5.C 6.B 7.A 8.D 9.C 10.A 11.B 12.A 13.D 14.C 15.C 16.D 17.A 18.B 19.C 20.A 21.D 22.D 23.A 24.B 25.D 26.A 27.D 28.B 29.C 30.C
31.A 32.C 33.B 34.C 35.B 36.B 37.A 38.D 39.A 40.C
二、填空题:
(1)A B C D E F 5 4 3 2 1 (2)15 (3)EDBGHFCA (4)程序 (5)课号
(6)(x%3==0) && (x%7==0) (7)4 (8)7 (9)123569 (10)135
(11)101418 (12)fabcde (13)x%10 (14)\0 (15)p
2009年9月全国计算机等级考试二级C笔试试卷
一、选择题
(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-S图 B) PAD图 C) 程序流程图 D) E-R图
(8)数据库管理系统是
A)操作系统的一部分 B) 在操作系统支持下的系统软件
C) 一种编译系统 D) 一种操作系统
(9)在E-R图中,用来表示实体联系的图形是
A) 椭圆图 B) 矩形 C) 菱形 D) 三角形
(10)有三个关系R,S和T如下:
其中关系T由关系R和S通过某种操作得到,该操作为
A) 选择 B)投影 C) 交 D) 并
(11)以下叙述中正确的是
A)程序设计的任务就是编写程序代码并上机调试 B)程序设计的任务就是确定所用数据结构
C)程序设计的任务就是确定所用算法 D)以上三种说法都不完整
(12)以下选项中,能用作用户标识符的是
A)void B)8_8 C)_0_ D)unsigned
(13)阅读以下程序
#include
main()
{ int case; float printF;
printf(“请输入2个数:”);
scanf(“%d %f”,&case,&pjrintF);
printf(“%d %f\n”,case,printF);
}
该程序编译时产生错误,其出错原因是
A)定义语句出错,case是关键字,不能用作用户自定义标识符
B)定义语句出错,printF不能用作用户自定义标识符
C)定义语句无错,scanf不能作为输入函数使用
D)定义语句无错,printf不能输出case的值
(14)表达式:(int)((double)9/2)-(9)%2的值是
A)0 B)3 C)4 D)5
(15)若有定义语句:int x=10;,则表达式x-=x+x的值为
A)-20 B)-10 C)0 D)10
(16)有以下程序
#include
main()
{ int a=1,b=0;
printf(“%d,”,b=a+b);
printf(“%d\n”,a=2*b);
}
程序运行后的输出结果是
A)0,0 B)1,0 C)3,2 D)1,2
(17)设有定义:int a=1,b=2,c=3;,以下语句中执行效果与其它三个不同的是
A)if(a>b) c=a,a=b,b=c; B)if(a>b) {c=a,a=b,b=c;}
C)if(a>b) c=a;a=b;b=c; D)if(a>b) {c=a;a=b;b=c;}
(18)有以下程序
#include
main()
{ int c=0,k;
for (k=1;k<3;k++)
switch (k)
{ default: c+=k
case 2: c++;break;
case 4: c+=2;break;
}
printf(“%d\n”,c);
}
程序运行后的输出结果是
A)3 B)5 C)7 D)9
(19)以下程序段中,与语句:k=a>b?(b>c?1:0):0;功能相同的是
A)if((a>b)&&(b>c)) k=1;
else k=0;
B)if((a>b)||(b>c) k=1;
else k=0;
C)if(a<=b) k=0;
else if(b<=c) k=1;
D)if(a>b) k=1;
else if(b>c) k=1;
else k=0;
(20)有以下程序
#include
main()
{ char s[]={“012xy”};int i,n=0;
for(i=0;s[i]!=0;i++)
if(s[i]>=’a’&&s[i]<=’z’) n++;
printf(“%d\n”,n);
}
程序运行后的输出结果是
A)0 B)2 C)3 D)5
(21)有以下程序
#include
main()
{ int n=2,k=0;
while(k++&&n++>2);
printf(“%d %d\n”,k,n);
}
程序运行后的输出结果是
A)0 2 B)1 3 C)5 7 D)1 2
(22)有以下定义语句,编译时会出现编译错误的是
A)char a=’a’; B)char a=’\n’;
C)char a=’aa’; D)char a=’\x2d’;
(23)有以下程序
#include
main()
{ char c1,c2;
c1=’A’+’8’-‘4’;
c2=’A’+’8’-‘5’;
printf(“%c,%d\n”,c1,c2);
}
已知字母A的ASCII码为65,程序运行后的输出结果是
A)E,68 B)D,69 C)E,D D)输出无定值
(24)有以下程序
#include
void fun(int p)
{ int d=2;
p=d++; printf(“%d”,p);}
main()
{ int a=1;
fun(a); printf(“%d\n”,a);}
程序运行后的输出结果是
A)32 B)12 C)21 D)22
(25)以下函数findmax拟实现在数组中查找最大值并作为函数值返回,但程序中有错导致不能实现预定功能
#define MIN -2147483647
int findmax (int x[],int n)
{ int i,max;
for(i=0;i
{ max=MIN;
if(max
return max;
}
造成错误的原因是
A)定义语句int i,max;中max未赋初值
B)赋值语句max=MIN;中,不应给max赋MIN值
C)语句if(max
D)赋值语句max=MIN;放错了位置
(26)有以下程序
#include
main()
{ int m=1,n=2,*p=&m,*q=&n,*r;
r=p;p=q;q=r;
printf(“%d,%d,%d,%d\n”,m,n,*p,*q);
}
程序运行后的输出结果是
A)1,2,1,2 B)1,2,2,1 C)2,1,2,1 D)2,1,1,2
(27)若有定义语句:int a[4][10],*p,*q[4];且0≤i<4,则错误的赋值是
A)p=a B)q[i]=a[i] C)p=a[i] D)p=&a[2][1]
(28)有以下程序
#include
#include
main()
{ char str[ ][20]={“One*World”, “One*Dream!”},*p=str[1];
printf(“%d,”,strlen(p));printf(“%s\n”,p);
}
程序运行后的输出结果是
A)9,One*World B)9,One*Dream
C)10,One*Dream D)10,One*World
(29)有以下程序
#include
main()
{ int a[ ]={2,3,5,4},i;
for(i=0;i<4;i++)
switch(i%2)
{ case 0:switch(a[i]%2)
{case 0:a[i]++;break;
case 1:a[i]--;
}break;
case 1:a[i[=0;
}
for(i=0;i<4;i++) printf(“%d”,a[i]); printf(“\n”);
}
A)3 3 4 4 B)2 0 5 0 C)3 0 4 0 D)0 3 0 4
(30)有以下程序
#include
#include
main()
{ char a[10]=”abcd”;
printf(“%d,%d\n”,strlen(a),sizeof(a));
}
程序运行后的输出结果是
A)7,4 B)4,10 C)8,8 D)10,10
(31)下面是有关C语言字符数组的描述,其中错误的是
A)不可以用赋值语句给字符数组名赋字符串 B)可以用输入语句把字符串整体输入给字符数组
C)字符数组中的内容不一定是字符串 D)字符数组只能存放字符串
(32)下列函数的功能是
fun(char * a,char * b)
{ while((*b=*a)!=’\0’) {a++,b++;} }
A)将a所指字符串赋给b所指空间 B)使指针b指向a所指字符串
C)将a所指字符串和b所指字符串进行比较 D)检查a和b所指字符串中是否有’\0’
(33)设有以下函数
void fun(int n,char * s) {……}
则下面对函数指针的定义和赋值均是正确的是
A)void (*pf)();
展开阅读全文