1、2010/3月全国计算机二级C语言一、选择题()()、()()每题分,()()每题分,共分)()下列叙述中正确的是)对长度为的有序链表进行查找,最坏情况下需要的比较次数为)对长度为的有序链表进行对分查找,最坏情况下需要的比较次数为(n/2)对长度为的有序链表进行对分查找,最坏情况下需要的比较次数为(log2n)对长度为的有序链表进行对分查找,最坏情况下需要的比较次数为(log2n)()算法的时间复杂度是指)算法的执行时间 )算法所处理的数据量)算法程序中的语句或指令条数 )算法在执行过程中所需要的基本运算次数()软件按功能可以分为:应用软件、系统软件和支撑软件(或工具软件)。下面属于系统软件的
2、是)编辑软件 )操作系统 )教务管理系统 )浏览器()软件(程序)调试的任务是)诊断和改正程序中的错误 )尽可能多地发现程序中的错误)发现并改正程序中的所有错误 )确定程序中错误的性质()数据流程图(图)是)软件概要设计的工具 )软件详细设计的工具)结构化方法的需求分析工具 )面向对象方法的需求分析工具()软件生命周期可分为定义阶段,开发阶段和维护阶段。详细设计属于)定义阶段 )开发阶段 )维护阶段 )上述三个阶段()数据库管理系统中负责数据模式定义的语言是)数据定义语言 )数据管理语言 )数据操纵语言 )数据控制语言()在学生管理的关系数据库中,存取一个学生信息的数据单位是)文件 )数据库
3、)字段 )记录()数据库设计中,用图来描述信息结构但不涉及信息在计算机中的表示,它属于数据库设计的)需求分析阶段 )逻辑设计阶段 )概念设计阶段 )物理设计阶段()有两个关系和如下: R T A B C a12b22c32d32ABCc32d32 则由关系得到关系的操作是)选择 )投影 )交 )并()以下叙述正确的是)语言程序是由过程和函数组成的 )语言函数可以嵌套调用,例如:fun(fun()语言函数不可以单独编译 )语言中除了main函数,其他函数不可作为单独文件形式存在()以下关于语言的叙述中正确的是)语言中的注释不可以夹在变量名或关键字的中间)语言中的变量可以在使用之前的任何位置进行定
4、义)在语言算术表达式的书写中,运算符两侧的运算数类型必须一致)语言的数值常量中夹带空格不影响常量值的正确表示()以下语言用户标识符中,不合法的是) ) ) )()若有定义:;,;,则不符合语言规定的赋值语句是),; )()(); ); )!a;()有以下程序#includemain()char a,b,c,d; scanf(“%c%c”,&a,&b); c=getchar();d=getchar; printf(“%c%c%c%cn”,a,b,c,d);当执行程序时,按下列方式输入数据(从第列开始,代表回车,注意:回车也是一个字符)则输出结果是) ) ) ) 4()以下关于语言数据类型使用的叙
5、述中错误的是)若要准确无误差的表示自然数,应使用整数类型)若要保存带有多位小数的数据,应使用双精度类型)若要处理如“人员信息”等含有不同类型的相关数据,应自定义结构体类型)若只处理“真”和“假”两种逻辑值,应使用逻辑类型()若是数值类型,则逻辑表达式()(! )的值是) ) ) )不知道的值,不能确定()以下选项中与if(a=1)a=b;else a+;语句功能不同的switch语句是)switch() )switch(a=1) )switch() )switch(a=1)case:;break; case:;break; default:a+;break; case:=;break;defa
6、ult:a+; case:a+; case:; case:a+;()有如下嵌套的语句 ()有以下程序if(ab) #includeif(ac) k=a; main()else k=c; int i,j,m=1;if(bc) k=b; for(i=1;i0;j-))k=(a3) break;)k=(ab)?(bc)?a:b)(bc)?b:c); m*=i*j;)k=(ab)?(ac)?a:c)(bc)?b:c); printf(“m=%dn”,m);程序运行后的输出结果是)k=(ab)?a:b;k=(ac)?a:c; ) )()有以下程序 ()有以下程序,其中的初值为八进制数#include #
7、includemain() main()int a=1,b=2; int k=011;for(;a8;a+) b+=a;a+=2; printf(“%dn”,k+);printf(“%d,%dn”,a,b);程序运行后的输出结果是 程序运行后的输出结果是), ), ) ) ) ), ),()下列语句组中,正确的是)char *s;s=Olympic; )char s7;s=Olympic;)char *s;sOlympic; )char s7;s=Olympic;()以下关于return语句的叙述中正确的是)一个自定义函数中必须有一条return语句)一个自定义函数中可以根据不同情况设置多条r
8、eturn语句)定义成void类型的函数中可以有带返回值的return语句)没有return语句的自定义函数在执行结束时不能返同到调用处()下列选项中,能正确定义数组的语句是)int num0.2008; )int num;)int N=2008 ; )#define N 2008int numN; int numN;()有以下程序#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);程序运行后的输出结果是), ),
9、), ),()若有定义int(*pt)3;,则下列说法正确的是)定义了基类型为int的三个指针变量 )定义了基类型为int的具有三个元素的指针数组pt)定义了一个名为*pt、具有三个元素的整型数组)定义了一个名为pt的指针变量,它可以指向每行有三个整数元素的二维数组()设有定义double a10,*s;,以下能够代表数组元索a3的是)(*s)3 )*(s+3) )*s3 )*s+3()有以下程序 ()有以下程序#include #includemain() main()int a5=1,2,3,4,5,b5=0,2,1,3,0,i,s=0; int b33=0,1,2,0,1,2,0,1,2
10、,i,j,t=1;for(i=1;i3;i+) s=s+abi; for(i=1;i3;i+)printf(“%dn”,s);程序运行后的输出结果是 for(j=1;j=1;j+) t+=bibji;) ) printf(“%dn”,t);程序运行后的输出结果是) ) ) ) ) )()若有以下定义和语句char s110abcd!,s2=n123;printf(,strlen(s1),strlen(s2);则输出结果是) ) ) )()有以下程序 ()有以下程序#include #include#define N 8 int f(int t,int n);void fun(int *x,in
11、t i) main()*x=*x+i; int a4=1,2,3,4,s;main() s=f(a,4);printf(“%dn”,s);int aN=1,2,3,4,5,6,7,8,i; int f(int t,int n)fun(a,2); for(i=1;i0)return tn-1+f(t,n-1);printf(“%d”,ai); else return 0;printf(“n”);程序运行后的输山结果是 程序运行后的输出结果是) ) ) ) ) ) ) )()有以下程序 ()有以下程序#include #includeint fun( ) #define SUB(a) (a)-(a
12、)static int x=1; main()x*=2;return x; int a=2,b=3,c=5,d;main() d=SUB(a+b)*c;int i,s=1; printf(“%dn”,d);for(i=1;i=2;i+) s=fun(); 程序运行后的输山结果是printf(“%dn”,s);程序运行后的输出结果是 ) ) ) ) ) ) ()设有定义:struct complexint real,unreal; data1=1,8,data2;则以下赋值语句中错误的是)data2data1; )data2(,);)data2realdata1real; )data2reald
13、ata1unreal;()有以下程序 ()有以下定义和语句#include struct workers#include int num;char name20;char c;struct A struct int a;char b10;double c; int day;int month;int year;svoid f(struct At); s truct workers w,*pw;main() pw=&w;能给中year成员赋1980的语句是struct Aa=1001,“ZhangDa”,1098.0;f(a); ); printf(“%d,%s,%6.1fn”,a.a,a.b,
14、a.c); );void f(struct At) ); t.a=1002;strcpy(t.b,“ChangRong”);t.c=1202.0;输出结果是 );), ),), ),()有以下程序 ()有以下程序#include #includemain() main()int a=2,b=a,c=2; FILE *fp;char str10;printf(“%dn”,a/b&c); fp=open(“myfile.dat”,“w”); fputs(“abc”,pf);close(pf);程序运行后的输出结果是 fp=open(“myfile.dat”,“a+”);) ) fprintf(pf
15、,“%d”,28); rewind(pf);) ) fscanf(pf,“%s”,str);puts(str);close(pf);程序运行后的输出结果是) ) ) )因类型不一致而出错二、填空题(每空分,共分)请将每空的正确答案写在答题卡【】【】序号的横线上,答在试卷上不得分。()一个队列的初始状态为空。现将元素,依次入队,然后再依次退队,则元素退队的顺序为【】。()设某循环队列的容量为50,如果头指针front45(指向队头元素的前一位置),尾指针rear10(指向队尾元素),则该循环队列中共有【】个元素。()设二叉树如下:AB C D F E G H 对该二叉树进行后序遍历的结果为【】。
16、 ()软件是【】数据和文档的集合。()有一个学生选课的关系,其中学生的关系模式为:学生(学号,姓名,班级,年龄),课程的关系模式为:课程(课号,课程名,学时),其中两个关系模式的键分别是学号和课号,则关系模式选课可定义为:选课(学号,【】,成绩)。()设为int型变量,请写出一个关系表达式【】,用以判断同时为和的倍数时,关系表达式的值为真。()有以下程序 ()有以下程序#include #includemain() main()int a=1,b=2,c=3,d=0; int m,n;if(a=1) scanf(“%d%d”,&m,&n); if(b!=2) while(m!=n)if(c=3
17、) d=1; while(mn) m=m-n; else d=2; while(mn) n=n-m;else if(c!=3) d=3; printf(“%dn”,m);else d=4; 程序运行后,当输入14 63回车时,else d=5;printf(“%dn”,d);程序远行后的输出结果是【】。 输出结果是【】。()有以下程序 ()有以下程序#include #includemain() main()int i,j,a3=1,2,3,4,5,6,7,8,9; int a=1,2,3,4,5,6,*k3,i=0;for(i=1;i3;i+) while(i3)for(j=1;j3;i+)
18、 printf(“%d”,aij); ki=&a2*i;printf(“n”); printf(“%d”,*ki); i+;程序运行后的输出结果是【】 程序运行后的输出结果是【10】。()有以下程序 ()有以下程序#include #includemain() #includeint a33=1,2,3,4,5,6,7,8,9; void fun(char *str)int b3=0,i; char temp;int n,i;for(i=1;i3;i+) bi=ai2+a2i; n=strlen(str);or(i=1;i0;i-) ()以下程序的功能是:将值为三位正整数的变量中的 main(
19、)数值按照个位、 stri=stri-1;str0=temp;十位、百位的顺序 char s50;scanf(“%s”,s);fun(s);printf(“%sn”,s);拆分并输出。请填空 。 程序运行后输入:abcdef回车,则输出结果#include 是【12】main() int x=256; printf(“%d-%d-%dn”,【13】,x/10%10,x/100);()以下程序用以删除字符串中所有的空格,请填空。 ()以下程序的功能是:借助指针变量#include 找出数组元素中的最大值及其元素的下标值main() 请填空。char100=“Our teacher teach c
20、 language!”;int i,j; #includefor(i=j=0;si!=0;i+) main()if(si!= ) sj=si;j+; int a10,*p,*s;sj=【14】; for(p=a;p-a10;p+) scanf(“%d”,p);printf(“%sn”,s); for(p=a,s=a;p-a*s) s=【15】;printf(“index=%dn”s-a);2009年9月全国计算机等级考试二级笔试试卷一、选择题(1)(10)、(21)(40)每题2分,(11)(20)每题1分,共70分)(1)下列数据结构中,属于非线性结构的是 C A)循环队列 B) 带链队列
21、C) 二叉树 D)带链栈(2)下列数据结果中,能够按照“先进后出”原则存取数据的是 A) 循环队列 B) 栈 C)队列 D)二叉树(3)对于循环队列,下列叙述中正确的是 A)队头指针是固定不变的 B)队头指针一定大于队尾指针C)队头指针一定小于队尾指针 D)队头指针可以大于队尾指针,也可以小于队尾指针(4)算法的空间复杂度是指 AA)算法在执行过程中所需要的计算机存储空间 B)算法所处理的数据量C)算法程序中的语句或指令条数 D)算法在执行过程中所需要的临时工作单元数(5)软件设计中划分模块的一个准则是A) 低内聚低耦合 B) 高内聚低耦合 C) 低内聚高耦合 D) 高内聚高耦合(6)下列选项
22、中不属于结构化程序设计原则的是 AA) 可封装 B) 自顶向下 C) 模块化 D) 逐步求精(7)软件详细设计产生的图如下:该图是A) N-S图 B) PAD图 C) 程序流程图 D) E-R图(8)数据库管理系统是A)操作系统的一部分 B) 在操作系统支持下的系统软件 C) 一种编译系统 D) 一种操作系统(9)在E-R图中,用来表示实体联系的图形是 CA) 椭圆图 B) 矩形 C) 菱形 D) 三角形(10)有三个关系R,S和T如下: 其中关系T由关系R和S通过某种操作得到,该操作为A) 选择 B) 投影 C) 交 D) 并(11)以下叙述中正确的是A)程序设计的任务就是编写程序代码并上机
23、调试 B)程序设计的任务就是确定所用数据结构C)程序设计的任务就是确定所用算法 D)以上三种说法都不完整(12)以下选项中,能用作用户标识符的是 CA)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);该程序编译时产生错误,其出错原因是 AA)定义语句出错,case是关键字,不能用作用户自定义标识符B)定义语句出错,printF不能用作
24、用户自定义标识符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,217)设有定义: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; B)if(ab)|(bc) k=1; C)if(ab) k=1;else k=0; else k=0; els