ImageVerifierCode 换一换
格式:DOCX , 页数:18 ,大小:31.85KB ,
资源ID:3527978      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/3527978.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(二级C笔试试题及答案.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

二级C笔试试题及答案.docx

1、二级C笔试试题及答案2007年4月全国计算机等级考试二级笔试试卷C语言程序设计(考试时间120分钟,满分100分)一、选择题((1)(10)每小题2分,(11)(50)每题1分,共60分)下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的,请将正确选项涂写在答题卡相应位置上,答在试卷上不得分。(1)下列叙述中正确的是(B)A)算法的效率只与问题的规模有关,而与数据的存储结构无关B)算法的时间复杂度是指执行算法所需要的计算工作量C)数据的逻辑结构与存储结构是一一对应的D)算法的时间复杂度与空间复杂度一定相关(2)在结构化程序设计中,模块划分的原则是(D)A)各模块应包括尽量多的功能B

2、)各模块的规模应尽量大C)各模块之间的联系应尽量紧密D)模块内具有高内聚度、模块间具有低耦合度(3)下列叙述中正确的是(A)A)软件测试的主要目的是发现程序中的错误B)软件测试的主要目的是确定程序中错误的位置C)为了提高软件测试的效率,最好由程序编制者自己来完成软件测试的工作D)软件测试是证明软件没有错误(4)下面选项中不属于面向对象程序设计特征的是(C)A)继承性B)多态性C)类比性D)封装性(5)下列对队列的叙述正确的是(D)A)队列属于非线性表B)队列按“先进后出”原则组织数据C)队列在队尾删除数据D)队列按“先进先出”原则组织数据 (6)对下列二叉树 A B CD E F X Y Z进

3、行前序遍历的结果为(C)A)DYBEAFCZXB)YDEBFZXCAC)ABDYECFXZD)ABCDEFXYZ(7)某二叉树中有n个度为2的结点,则该二叉树中的叶子结点数为(A)A)n+1B)n-1C)2nD)n/2(8)在下列关系运算中,不改变关系表中的属性个数但能减少元组个数的是(B)A)并B)交C)投影D)笛卡儿乘积(9)在E-R图中,用来表示实体之间联系的图形是(C)A)矩形B)椭圆形C)菱形D)平行四边形(10)下列叙述中错误的是(A)A)在数据库系统中,数据的物理结构必须与逻辑结构一致B)数据库技术的根本目标是要解决数据的共享问题C)数据库设计是指在已有数据库管理系统的基础上建立

4、数据库D)数据库系统需要操作系统的支持(11)算法中,对需要执行的每一步操作,必须给出清楚、严格的规定,这属于算法的(C) A)正当性 B)可行性 C)确定性 D)有穷性 (12)下列叙述中错误的是(D)A)计算机不能直接执行用C语言编写的源程序B)C程序经C编译程序编译后,生成后缀为.obj的文件是一个二进制文件C)后缀为.obj的文件,经连接程序生成后缀为.exe的文件是一个二进制文件D)后缀为.obj和.exe的二进制文件都可以直接运行(13)按照C语言规定的用户标识符命名规则,不能出现在标识符中的是(B)A)大写字母 B)连接符 C)数字字符 D)下划线(14)以下叙述中错误的是(C)

5、 A)C语言是一种结构化程序设计语言B)结构化程序有顺序、分支、循环三种基本结构组成C)使用三种基本结构构成的程序只能解决简单问题D)结构化程序设计提倡模块化的设计方法(15)对于一个正常运行的C程序,以下叙述中正确的是(A)A)程序的执行总是从main函数开始,在main函数结束B)程序的执行总是从程序的第一个函数开始,在main函数结束C)程序的执行总是从main函数开始,在程序的最后一个函数中结束D)程序的执行总是从程序的第一个函数开始,在程序的最后一个函数中结束(16)设变量均已正确定义,若要通过scanf(“%d%c%d%c”,&a1,&c1,&a2,&c2);语句为变量a1和a2赋

6、数值10和20,为变量c1和c2赋字符X和Y。以下所示的输入形式中正确的是(注:代表空格字符)(D)A)10X20Y回车 B)10X20Y回车 C)10X回车 D)10X回车 20Y回车 20Y回车(17)若有代数式(其中e仅代表自然对数的底数,不是变量),则以下能够正确表示该代数式的C语言表达式是(C)A)sqrt(abs(nx+ex) B) sqrt(fabs(pow(n,x)+pow(x,e)C)sqrt(fabs(pow(n,x)+exp(x) D) sqrt(fabs(pow(x,n)+exp(x)(18)设有定义:int k=0;,以下选项的四个表达式中与其他三个表达式的值不相同的

7、是(A)A)k+ B)k+=1 C)+k D)k+1(19)有以下程序,其中%u表示按无符号整数输出(B)main()unsigned int x=0xFFFF; /* x的初值为十六进制数 */ printf(“%un”,x);程序运行后的输出结果是A)-1 B)65535 C)32767 D)0xFFFF(20)设变量x和y均已正确定义并赋值,以下if语句中,在编译时将产生错误信息的是(C)A)if(x+); B)if(xy&y!=0); C)if(xy) x- - D)if(y0&n5);程序运行后的输出结果是A)235 B)0235 C)02356 D)2356(24)有以下程序mia

8、n()int i,j; for(i=1;i4;i+)for(j=i;j4;j+) printf(“%d*%d=%d “,i,j,i*j);printf(“n”);程序运行后的输出结果是(B)A) 1*1=1 1*2=2 1*3=3 B) 1*1=1 1*2=2 1*3=32*1=2 2*2=4 2*2=4 2*3=63*1=3 3*3=9 C) 1*1=1 D) 1*1=1 1*2=2 2*2=4 2*1=2 2*2=4 1*3=3 2*3=6 3*3=9 3*1=3 3*2=6 3*3=9(25)以下合法的字符型常量是(A) A)”x13” B)”018” C)”65” D)”n” (26)

9、在C语言中,函数返回值的类型最终取决于(A) A)函数定义时在函数首部所说明的函数类型 B)return语句中表达式值的类型 C)调用函数时主函数所传递的实参类型 D)函数定义时形参的类型(27)已知大写字母A的ASCII码是65,小写字母aASCII码是97,以下不能将变量c中大写字母转换为对应小写字母的语句是(D) A)c=(c-A)%26+a B)c=c+32 C)c=c-A+a D)c=(A+c)%26-a (28)有以下函数 int fun(char *s) char *t=s; while(*t+); return(t-s); 该函数的功能是(B)A)比较两个字符的大小 B)计算s

10、所指字符串占用内存字节的个数C)计算s所指字符串的长度 D)将s所指字符串复制到字符串t中(29)设已有定义:float x;则以下对指针变量p进行定义且赋初值的语句中正确的是(D) A)float *p=1024; B)int *p=(float x);C)float p=&x; D)float *P=&x; (30)有以下程序 #include main() int n,*p=NULL;*p=&n;printf(“Input n:”); scanf(“%d”,&p); printf(“output n:”); printf(“%dn”,p);该程序试图通过指针p为变量n读入数据并输出,但程

11、序有多处错误,以下语句正确的是(A)A)int n,*p=NULL; B)*p=&n; C)scanf(“%d”,&p) D)printf(“%dn”,p);(31)以下程序中函数f的功能是:当flag为1时,进行有由小到大排序;当flag为0时,进行由大到小排序。 void f(int b,int n,int flag) int i,j,t;for(i=0;in-1;i+) for (j=i+1;jbj:bibj) t=bi;bi=bj;bj=t; main()int a10=5,4,3,2,1,6,7,8,9,10,i; f(&a2,5,0); f(a,5,1); for(i=0;i10;

12、i+) printf(“%d,”ai);程序运行后的输出结果是(B)A)1,2,3,4,5,6,7,8,9,10, B)3,4,5,6,7,2,1,8,9,10,C)5,4,3,2,1,6,7,8,9,10, D)10,9,8,7,6,5,4,3,2,1,(32)有以下程序void f(int b)int i; for(i=2;i6;i+) bi*=2; main()int a10=1,2,3,4,5,6,7,8,9,10,i;f(a);for(i=0;i10;i+) printf(“%d,”,ai);程序运行后的输出结果是(B)A)1,2,3,4,5,6,7,8,9,10,B)1,2,6,8

13、,10,12,7,8,9,10C)1,2,3,4,10,12,14,16,9,10, D)1,2,6,8,10,12,14,16,9,10,(33)有以下程序 typedef structint b,p;A; void f(A c) /*注意:c是结构变量名 */ int j;c.b+=1; c.p+=2;main()int i;A a=1,2;f(a);printf(“%d,%dn”,a.b,a.p);程序运行后的输出结果是(D) A)2,3 B)2,4 C)1,4 D)1,2(34)有以下程序main()int a44=1,4,3,2,8,6,5,7,3,7,2,5,4,8,6,1,i,j

14、,k,t;for(i=0;i4;i+) for(j=0;j3;j+) for(k=j+1;kaki)t=aji;aji=aki;aki=t;/*按列排序*/ for(i=0;i4;i+)printf(“%d,”,aij);程序运行后的输出结果是(A) A)1,6,5,7, B)8,7,3,1, C)4,7,5,2, D)1,6,2,1,(35) 有以下程序main()int a44=1,4,3,2,8,6,5,7,3,7,2,5,4,8,6,1,i,k,t;for(i=0;i3;i+) for(k=i+i;k4;k+) if(aiiakk)t=aii;aii=akk;akk=t;for(i=0

15、;i4;i+)printf(“%d,”,a0i);程序运行后的输出结果是(B)A)6,2,1,1, B)6,4,3,2, C)1,1,2,6, D)2,3,4,6,(36) 有以下程序void f(int *q)int i=0;for( ; i5;i+)(*q)+;main()int a5=1,2,3,4,5,i;f(a);for(i=0;i5;i+)printf(“%d,”,ai);程序运行后的输出结果是(B)A)2,2,3,4,5, B)6,2,3,4,5, C)1,2,3,4,5, D) 2,3,4,5,6,(37) 有以下程序#include main()char p20=a,b,c,

16、d,q=”abc”, r=”abcde”;strcpy(p+strlen(q),r); strcat(p,q);printf(“%d%dn”,sizeof(p),strlen(p);程序运行后的输出结果是(C)A)20 9 B)9 9 C)20 11 D)11 11 (38) 有以下程序 #include main()char p20=a,b,c,d,q=”abc”, r=”abcde”strcat(p,r); Strcpy(p+strlen(q),q);Printf(“%d n”,sizeof(p);程序运行后的输出结果是(B)A)9 B)6 C)11 D)7(39) 有以下程序#inclu

17、de main()void f(char p10, int n ) /* 字符串从小到大排序 */ char t10; int i,j; for(i=0;in-1;i+) for(j=i+1;j0) strcpy(t,pi); strcpy(pi,pj); strcpy(pi,t); main() char p510=“abc”,”aabdfg”,”abbd”,”dcdbe”,”cd”;f(p,5); printf(“%dn”,strlen(p0);程序运行后的输出结果是(C)A) 2 B) 4 C) 6 D) 3(40) 有以下程序void f(int n, int *r)int r1=0;

18、 if(n%3=0) r1=n/3;else if(n%5=0) r1=n/5;else f(-n,&r1);*r=r1;main()int m=7,r; f(m,&r); printf(“%dn,r”);程序运行后的输出结果是(A)A) 2 B) 1 C)3 D) 0(41)有以下程序 main(int argc,char *argv) int n=0,i;for(i=1;iargc;i+) n=n*10+*argvi-0;printf(“%dn”,n); 编译连接后生成可执行文件tt.exe,若运行时输入以下命令行tt 12 345 678程序运行后的输出结果是(D)A) 12 B) 12

19、345 C)12345678 D) 136(42) 有以下程序int a=4;int f(int n)int t=0; static int a=5; if(n%2) int a=6; t+=a+;else int a=7 ;+=a+;return t+a+;main()int s=a,i=0;for(;i2;i+) s+=f(i);printf (“%dn”,s);程序运行后的输出结果是(B)A)24 B)28 C)32 D)36(43) 有一个名为init.txt的文件,内容如下:#define HDY(A,B) A/B# define PRINT(Y) Printf(“y=%dn.,Y)

20、有以下程序#include “init.txt”main()int a=1,b=2,c=3,d=4,k;K=HDY(a+c,b+d);PRINT(K);下面针对该程序的叙述正确的是(D)A)编译有错 B)运行出错 C)运行结果为 y=0 D) 运行结果为 y=6(44) 有以下程序main()char ch=“uvwxyz”,*pc; Pc=ch; printf(“%cn”,*(pc+5);程序运行后的输出结果是(A)A)z B)0 C)元素ch5的地址 D)字符y的地址(45) 有以下程序struct S int n; int a20;void f(struct S *P)int i,j,t

21、;for(i=0;in-1;i+)for(j=i+1;jn;j+)if(p-aip-aj) t=p-ai; p-ai=p-aj; p-aj=t; main()int i; struct S s=10,2,3,1,6,8,7,5,4,10,9;f(&s);for(i=0;is.n;i+) printf(“%d”,s.ai);程序运行后的输出结果是(A)A)1,2,3,4,5,6,7,8,9,10, B)10,9,8,7,6,5,4,3,2,1, C)2,3,1,6,8,7,5,4,10,9, D)10,9,8,7,6,1,2,3,4,5,(46) 有以下程序struct S int n; int

22、 a20; ;void f(int *a,int n)int i; for(i=0;in-1;i+) ai+=i;main()int i; struct S s=10,2,3,1,6,8,7,5,4,10,9;f(s.a, s.n);for(i=0;is.n;i+) printf(“%d”,s.ai);程序运行后的输出结果是(A)A)2,4,3,9,12,12,11,11,18,9, B)3,4,2,7,9,8,6,5,11,10, C)2,3,1,6,8,7,5,4,10,9, D)1,2,3,6,8,7,5,4,10,9,(47) 有以下程序段typedef struct node int

23、 data; struct node *next; *NODE;NODE p;以下叙述正确的是(C)A)p是指向struct node结构变量的指针的指针B)NODE p;语句出错C)p是指向struct node结构变量的指针D)p是struct node结构变量(48)有以下程序main()unsigned char a=2,b=4,c=5,d; d=a|b; d&=c; printf(“%dn”,d); 程序运行后的输出结果是(B)A)3 B)4 C)5 D)6(49)有以下程序#include main()FILE *fp; int k,n,a6=1,2,3,4,5,6;fp=fope

24、n(“d2.dat”,”w”);fprintf(fp,”%d%dn”,a0,a1,a2); fprintf(fp, “%d%d%d n”,a3,a4,a5);fclose(fp);fp=fopen(“d2.dat”,”r”);fscanf(fp, “%d%d”,&k,&n); printf(“%d%dn”,k,n);fclose(fp);程序运行后的输出结果是(D)A)1 2 B)1 4 C)123 4 D) 123 456(50)有以下程序#include main ()FILE *fp; int i,a6=1,2,3,4,5,6k;fp=fopen(“d3.dat”,”w+b”);fwri

25、te(a,sizeof(int),6,fp);fseek(fp,sizeof(int)*3,SEEK_SET);/*该语句使读文件的位置指针从文件头向后移动3个int型数据*/fread(a,sizeof(int),3,fp); fclose(fp);for(i=0;i6;i+) printf(“%d,”,ai);程序运行后的输出结果是(A)A)4,5,6,4,5,6, B)1,2,3,4,5,6, C)4,5,6,1,2,3, D)6,5,4,3,2,1,二填空题(每空2分,共40分)请将每一个空的正确答案写在答题卡1至20序号的横线上,答在试卷上不得分。注意:以命令关键字填空的必须写完整(

26、1) 在深度为7的满二叉树中,度为2的结点个数为_63_。(2) 软件测试分为白箱(盒)测试和黑箱(盒)测试,等价类划分法属于_黑箱(或黑盒) 测试。(3) 在数据库系统中,实现各种数据管理功能的核心软件称为 _数据库管理系统_。(4) 软件生命周期可分为多个阶段,一般分为定义阶段、开发阶段和维护阶段。编码和测试属于 开发_阶段。(5)在结构化分析使用的数据流图(DFD)中,利用数据字典 对其中的图形元素进行确切解释。(6)执行以下程序后的输出结果是 a=14 。main()int a=10; a=(3*5,a+4); printf(“a=%dn”,a);(7) 当执行以下程序时,输入1234567890,则其中while循环体将执行 0 次。include main()char ch; While(ch=getchar()=0) printf(“#”); (8) 以下程序的运行结果是 m=4k=4i=5k=5 。int k=0;void fun(int m) m+=k; k+=m; printf(“m=%dn k=%d ”,m,k+); main

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1