全国计算机二级c语言学习知识历年真命题完整编辑版.doc

收藏

编号:2578581    类型:共享资源    大小:757.54KB    格式:DOC    上传时间:2020-04-21
14
金币
关 键 词:
全国计算机 二级 语言 学习 知识 历年 命题 完整 完全 编辑 编纂
资源描述:
.\ 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)();
展开阅读全文
提示  淘文阁 - 分享文档赚钱的网站所有资源均是用户自行上传分享,仅供网友学习交流,未经上传用户书面授权,请勿作他用。
关于本文
本文标题:全国计算机二级c语言学习知识历年真命题完整编辑版.doc
链接地址:https://www.taowenge.com/p-2578581.html
关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

收起
展开