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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

历年二级C语言笔试真题及详细答案.docx

1、历年二级C语言笔试真题及详细答案2011年9月全国计算机等级考试二级笔试试卷C语言程序设计一、选择题下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的。(1)下列叙述中正确的是(D)。A)算法就是程序 B)设计算法时只需要考虑数据结构的设计C)设计算法时只需要考虑结果的可靠性 D)以上三种说法都不对(2)下列关于线性链表的叙述中,正确的是(C)。A)各数据结点的存储空间可以不连续,但它们的存储顺序与逻辑顺序必须一致B)各数据结点的存储顺序与逻辑顺序可以不一致,但它们的存储空间必须连续C)进行插入与删除时,不需要移动表中的元素D)以上三种说法都不对(3)下列关于二叉树的叙述中,正确的

2、是(B)。A)叶子结点总是比度为2的结点少一个B)叶子结点总是比度为2的结点多一个C)叶子结点数是度为2的结点数的两倍D)度为2的结点数是度为1的结点数的两倍(4)软件按功能可以分为应用软件、系统软件和支撑软件(或工具软件)。下面属于应用软件的是(A)。A)学生成绩管理系统 B)C语言编译程序C)UNIX操作系统 D)数据库管理系统(5)某系统总体结构图如下图所示:该系统总体结构图的深度是(C)。A)7 B)6 C)3 D)2(6)程序调试的任务是(D)。A)设计测试用例 B)验证程序的正确性C)发现程序中的错误 D)诊断和改正程序中的错误(7)下列关于数据库设计的叙述中,正确的是(A)。A)

3、在需求分析阶段建立数据字典 B)在概念设计阶段建立数据字典C)在逻辑设计阶段建立数据字典 D)在物理设计阶段建立数据字典(8)数据库系统的三级模式不包括(D)。A)概念模式 B)内模式C)外模式 D)数据模式(9)有三个关系R、S利T如下:则由关系R和S得到关系T的操作是(B)。A)自然连接 B)差 C)交 D)并(10)下列选项中属于面向对象设计方法主要特征的是(A)。A)继承 B)自顶向下 C)模块化 D)逐步求精(11)以下叙述中错误的是(C)。A)C语言编写的函数源程序,其文件名后缀可以是.CB)C语言编写的函数都可以作为一个独立的源程序文件C)C语言编写的每个函数都可以进行独立的编译

4、并执行D)一个C语言程序只能有一个主函数(12)以下选项中关于程序模块化的叙述错误的是(C)。A)把程序分成若干相对独立的模块,可便于编码和调试B)把程序分成若干相对独立、功能单一的模块,可便于重复使用这些模块C)可采用自底向上、逐步细化的设计方法把若干独立模块组装成所要求的程序D)可采用自顶向下、逐步细化的设计方法把若干独立模块组装成所要求的程序(13)以下选项中关于C语言常量的叙述错误的是(D)。A)所谓常量,是指在程序运行过程中,其值不能被改变的量B)常量分为整型常量、实型常量、字符常量和字符串常量C)常量可分为数值型常量和非数值型常量D)经常被使用的变量可以定义成常量(14)若有定义语

5、句:int a=10;double b=3.14;,则表达式A+a+b值的类型是(C)。A)char B)int C)double D)float(15)若有定义语句:int x=12,y=8,z;,在其后执行语句z=0.9+x/y;,则z的值为(B)。A)1.9 B)1 C)2 D)2.4(16)若有定义:int a,b;,通过语句scanf(%d;%d,&a,&b);,能把整数3赋给变量a,5赋给变量b的输入数据是( C)。A)3 5 B)3,5 C)3;5 D)35(17)若有定义语句:int k1=10,k2=20;,执行表达式(k1=k1k2)&(k2=k2k1)后,k1和l(2的值

6、分别为( B)。A)0和1 B)0和20 C)10和1 D)10和20(18)有以下程序#includestdio.hmain() int a=1,b=0;if(-a)b+;else if(a=0) b+=2;else b+=3;printf(%dn,b);程序运行后的输出结果是( C)。A)0 B)1 C)2 D)3(19)下列条件语句中,输出结果与其他语句不同的是( D)。A)if(a)printf(%d-n,x); else printf(%dn,y);B)if(a=0)printf(%dn,y); else printf(%dn,x);C)if(a!=0)printf(%dn,x);

7、else printf(%dn,y);D)if(a=0)printf(%dn,x); else printf(%dn,y);(20)有以下程序#include stdio.hmain() int a=7;while(a-);pfintf(%dn,a);程序运行后的输出结果是(A )。A)-1 B)0 C)1 D)7(21)以下不能输出字符A的语句是(注:字符A的ASCII码值为65,字符a的ASCII码值为97)( B )A)printf(“%cn,a-32); B)printf(%dn,A);C)printf(%cn,65); D)printf(%cn,B-1);(22)有以下程序(注:字符

8、a的ASCII码值为97)#includestdio.hmain() char*s=abc;do printf(%d,s%10);+s;)while(*s);程序运行后的输出结果是( B)。A)abc B)789 C)7890 D)979899(23)若有定义语句:double a,*p=&a;以下叙述中错误的是(A )。A)定义语句中的+号是一个间址运算符B)定义语句中的*号只是一个说明符C)定义语句中的p只能存放double类型变量的地址D)定义语句中,*p=&a把变量a的地址作为初值赋给指针变量p(24)有以下程序#includestdio.hdouble f(double x);mai

9、n() double a=0;int i;for(i=0;i30;i+=10)a+=f(double)i);printf(%5.0fn,a);double f(double x)return x*x+1;程序运行后的输出结果是( A)。A)503 B)401 C)500 D)1404(25)若有定义语句:int year=2009,*p=&year;,以下不能使变量year中的值增至2010的语句是(D )。A)*p+=1; B)(*p)+; C)+(*p); D)*p+;(26)以下定义数组的语句中错误的是( C )。A)int num=1,2,3,4,5,6; B)int num3=1,2

10、,3,4,5,6);C)int num24=(1,2,3,4,5,6); D)int num4=1,2,3,4,5,6;(27)有以下程序#include stdio.hvoid fun(int *p) printf(%dn,p5);main() int a10=1,2,3,4,5,6,7,8,9,10;fun(&a3);程序运行后的输出结果是( D )。A)5 B)6 C)8 D)9(28)有以下程序#includestdio.h#define N 4void fun(int aN,int b) int i;for(i=0;iN;i+)bi=aii-aiN-1-i;void main() i

11、nt xNN=1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,yN,i;fun(x,y);for(i=0;iN;i+)printf(%d,yi);printf(n);程序运行后的输出结果是(B )。A)-12,-3,0,0, B)-3,-1,1,3, C)0,1,2,3, D)-3,-3,-3,-3,(29)有以下函数int fun(char *x,char *y) int n=0;while(*x=*y)&*x!=0)x+; y+; n+;return n;函数的功能是( B )。A)查找x和y所指字符串中是否有0B)统计x和y所指字符串中最前面连续相同的字符个

12、数C)将y所指字符串赋给x所指存储空间D)统计x和y所指字符串中相同的字符个数(30)若有定义语句:char *s1=OK,*s2=ok;,以下选项中,能够输出OK的语句是( D )。A)if(strcmp(s1,s2)=0) puts(s1); B)if(strcmp(s1,s2)!=0) puts(s2);C)if(strcmp(s1,s2)=1) puts(s1,); D)if(strcmp(s1,s2)!=0)puts(s1);(31)以下程序的主函数中调用了在其前面定义的fun函数#include stdio.hmain() double a15,k;k=fun(a);则以下选项中错

13、误的fun函数受部是( D )。A)double fun(double a15) B)double fun(double *a)C)double fun(double a) D)double fun(double a)(32)有以下程序#includestdio.h#includestring.hmain()char a510=china,beijing,you,tiananmen,welcome);int i,j; char t10;for(i=0;i4;i+)for(j=i+1;j5;j+)if(strcmp(ai,aj)0)strcpy(t,ai);strcpy(ai,aj);strcp

14、y(aj,t);puts(a3);程序运行后的输出结果是( C )。A)Beijing B)china C)welcome D)tiananmen(33)有以下程序#includestdio.hint f(int m) static int n=0;n+=m;return n;main() int n=0;printf(%d,f(+n);printf(%dn,f(n+);程序运行后的输出结果是( A )。A)1,2 B)1,1 C)2,3 D)3,3(34)有以下程序#includestdio.hmain()char ch35=AAAA,BBB,CC;printf(%sn,ch1);程序运行后

15、的输出结果是( D )。A)AAAA B)CC C)BBBCC D)BBB(35)有以下程序#includestdio.h#includestring.hvoid fun(char*w,int m)char s,*p1,*p2;p1=w;p2=w+m-1;while(p1p2)s=*p1;*p1=*p2;*p2=s;p1+;p2-;main()char a=123456;fun(a,strlen(a);puts(a);程序运行后的输出结果是( A )。A)654321 B)116611 C)161616 D)123456(36)有以下程序#includestdio.h#includestrin

16、g.htypedef structchar name9;char sex;int score2;STU;STU f(STU a) STU b=Zhao,m,85,90);int i;strcpy(a.name,b.name);a.sex=b.sex;for(i=0;i2;i+)a.scorei=b.scorei;return a;main() STU c=Qian,f,95,92),d;d=f(c);printf(%s,%c,%d,%d,d.name,d.sex,d.score0,d.score1);printf(%s,%c,%d,%d,c.name,c.sex,c.score0,c.scor

17、e1);程序运行后的输出结果是( A )。A)Zhao,m,85,90,Qian,f,95,92 B)Zhao,m,85,90,Zhao,m,85,90C)Qian,f,95,92,Qian,f,95,92 D)Qian,f,95,92,Zhao,m,85,90(37)有以下程序#includestdio.hmain() struct nodeint n;struct node *next; *p;struct node x3=2,x+1,4,x+2,6,NULL;p=x;printf(%d,p-n);printf(%dn,p-next-n);程序运行后的输出结果是( B )。A)2,3 B)

18、2,4 C)3,4 D)4,6(38)有以下程序#includestdio.hmain() int a=2,b;b=a2;pfinff(%dn,b);程序运行后的输出结果是( D )。A)2 B)4 C)6 D)8(39)以下选项中叙述错误的是( A )。A)C程序函数中定义的赋有初值的静态变量,每调用一次函数,赋一次初值B)在C程序的同一函数中,各复合语句内可以定义变量,其作用域仅限本复合语句内C)C程序函数中定义的自动变量,系统不自动赋确定的初值D)C程序函数的形参不可以说明为static型变量(40)有以下程序#includestdio.hmain() FILE*fp;int k,n,i

19、,a6=1,2,3,4,5,6;fp=fopen(d2.dat,w);for(i=0;i6;i+)fprintfffp,%dn,ai);fclose(fp);fp=fopen(d2.dat,r);for(i=0;i3;i+)fscanf(fp,%d%d,&k,&n);fclose(fp);printf(%d,%dn,k,n);程序运行后的输出结果是( C )。A)1,2 B)3,4 C)5,6 D)123,456二、填空题请将每空的正确答案写在横线上。(1)数据结构分为线性结构与非线性结构,带链的栈属于_。(2)在长度为n的顺序存储的线性表中插入一个元素,最坏情况下需要移动表中_个元素。(3)

20、常见的软件开发方法有结构化方法和面向对象方法。对某应用系统经过需求分析建立数据流图(DFD),则应采用_方法。(4)数据库系统的核心是_。(5)在进行关系数据库的逻辑设计时,E-R图中的属性常被转换为关系中的属性,联系通常被转换为_。(6)若程序中已给整型变量a和b赋值10和20,请写出按以下格式输出a、b值的语句_。*a=10,b=20*(7)以下程序运行后的输出结果是_。#includestdio.hmain() int a=37;a%=9;printf(%dn,a);(8)以下程序运行后的输出结果是_。#includestdio.hmain() int i,j;for(i=6;i3;i-

21、)j=i;printf(%d%dn,i,j);(9)以下程序运行后的输出结果是_。#includestdio.hmain() int i,n=0,0,0,0,0);for(i=1;i=2;i+)ni=ni-1*3+1;printf(%d,ni);printf(n);(10)以下程序运行后的输出结果是_。#includestdio.hmain() char a;for(a=0;a15;a+=5) putchar(a+A);printf(n);(11)以下程序运行后的输出结果是_。#includestdio.hvoid fun(int x) if(x/50)fun(x/5);printf(%d,x

22、);main() fun(11);pfintf(n);(12)有以下程序#includestdio.hmain() int c3=0,k,i;while(k=getchar()!=n)ck-A+;for(i=0;i3;i+)printf(%d,ci);printf(n);若程序运行时从键盘输入ABCACC回车,则输出结果为_。(13)以下程序运行后的输出结果是_。#includestdio.hmain() int n2,i,j;for(i=0;i2;i+)ni=0;for(i=0;i2;i+)for(j=0;j2;j+)nj=ni+1;printf(%dn,n1);(14)以下程序调用fun函

23、数把x中的值插入到a数组下标为k的数组元素中。主函数中,n存放a数组中数据的个数。请填空。#includestdio.hvoid fun(int s,int *n,int k,int x) int i;for(i=*n-1;i=k;i-)s (14) =si;sk=x;*n=*n+ (15) ;main()int a20=1,2,3,4,5,6,7,8,9,10,11,i,x=0,k=6,n=11;fun(a,&n,k,x);for(i=0,in,i+)printf(%4d,ai);printf(n);2011年9月全国计算机等级考试二级C语言程序设计答案及详解一、选择题(1)D) 解析 所谓

24、算法是指解题方案的准确而完整的描述。是一组严谨地定义运算顺序的规则,并且每一个规则都是有效的,且是明确的,此顺序将在有限的次数下终止。算法不等于程序,也不等于计算方法。设计算法时不仅要考虑对数据对象的运算和操作,还要考虑算法的控制结构。(2)C) 解析 线性表的链式存储结构称为线性链表。在链式存储结构中,存储数据结构的存储空间可以不连续,各数据结点的存储顺序与数据元素之间的逻辑关系可以不一致,而数据元素之间的逻辑关系是由指针域来确定的。(3)B) 解析 由二叉树的性质可以知道在二叉树中叶子结点总是比度为2的结点多一个。(4)A) 解析 学生成绩管理系统为应用软件。(5)C) 解析 这个系统总体

25、结构图是一棵树结构,在树结构中,根结点在第1层,同一层上所有子结点都在下一层,由系统总体结构图可知,这棵树共3层。在树结构中,树的最大层次称为树的深度。所以这棵树的深度为3。(6)D) 解析 所谓程序调试,是将编制的程序投入实际运行前,用手工或编译程序等方法进行测试,修正语法错误和逻辑错误的过程。其任务是诊断和改正程序中的错误。(7)A) 解析 数据库设计目前一般采用生命周期法,即将整个数据库应用系统的开发分解成目标独立的若干阶段。分别是:需求分析阶段、概念设计阶段、逻辑设计阶段、物理设计阶段、编码阶段、测试阶段、运行阶段、进一步修改阶段。数据字典是对系统中数据的详尽描述,是各类数据属性的清单

26、。对数据设计来讲,数据字典是进行详细的数据收集和数据分析所获得的主要结果。(8)D) 解析 数据库系统的三级模式包括概念模式、外模式和内模式(物理模式)。(9)B) 解析 由三个关系R、S和T的结构可以知道,关系T是由关系R、S经过差运算得到的。(10)A) 解析 面向对象设计方法的主要特征有封装性、继承性和多态性。而结构化程序设计方法的主要原则有自顶向下,逐步求精,模块化,限制使用goto语句。(11)C) 解析 C语言程序是从main函数开始执行的,每一个函数可以进行独立的编译。(12)C) 解析 如果应用结构化程序设计方法设计程序,那么可采用自顶向下,逐步细化的设计方法把若干独立模块组装

27、成所要求的程序。(13)D) 解析 常量指在程序运行过程中,其值不能被改变的量。常量分为整型常量,也就是整常数,实型常量,字符型常量和字符串常量。常量也可以按数据类型分为为数据常量和非数据常量。变量是指在程序运行过程中,其值能被改变的量。(14)C) 解析 在C语言中不同类型的数据进行运算时,除了强制数据类型转换外,都要进行默认的数据类型转换,通常转换为精度较高的数据类型。对于本题来说,字符型数据A与整型a相加转换为整型数据,其和再与双精度型数据b相加,要转换为双精度型数据。(15)B) 解析 由于x,y,z都是整型数据,所以x除以y的值为整型数值1,1和0.9相加得到1.9,再转换为整型数1

28、赋给整型变量z。(16)C) 解析 在采用scanf这个函数输入数据时,要严格遵守其输入的规则定义。本题此函数定义的规则是,在两个整数之间加分号输入。(17)B) 解析 由于k1等于10,k2等于20,所以关系表达式k1k2的值为假,即等于0,所以在执行逻辑表达式(k1=k1k2)&(k2=k2k1)的第一个赋值表达式k1=k1k2执行后,k1的值等于0。又因为在逻辑与表达式中只要第一表达式的值为假时,整个逻辑表达式的值就为假,第二表达式不执行,k2值不改变。(18)C) 解析 由于变量a的初始值等于1,所以在程序中执行if(-a)后,a的值等于0,执行else if(a=0)b+=2;这条语句后,变量b的值等于2。(19)D) 解析 选项A)、B)、C)这三条语句都是在变量不等于0的情况下,输出x;等于0的情况下输出y,而选项D)则正好相反。(20)A) 解析 在while语句中,先判断while后面的表达式是否为0,如果为0,则退出循环,否则执行循环体。在本题中,当变量a的值

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

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