历年全国计算机二级C语言真题.pdf
《历年全国计算机二级C语言真题.pdf》由会员分享,可在线阅读,更多相关《历年全国计算机二级C语言真题.pdf(66页珍藏版)》请在得力文库 - 分享文档赚钱的网站上搜索。
1、2010年3月计算机等级考试二级C笔试题及答案一、选择题(1)下列叙述中正确的是A)对长度为n的有序链表进行查找,最坏清况下需要的比较次数为nB)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(n/2)C)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(log2n)D)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(nlog2n)(2)算法的时间复杂度是指A)算法的执行时间B)算法所处理的数据量C)算法程序中的语司或指令条数D)算法在执行过程中所需要的基本运算次数(3)软件按功能可以分为:应用软件、系统软件和支撑软件(或工具软件)。下面属于系统软件的是
2、A)编辑软件B)操作系统C)教务管理系统D)浏览器(4)软件(程序)调试的任务是A)诊断和改正程序中的错误B)尽可能多地发现程序中的错误C)发现并改正程序中的所有错误D)确定程序中错误的性质(5)数据流程图(DFD图)是A)软件概要设计的工具B)软件详细设计的工具C)结构化方法的需求分析工具D)面向对象方法的需求分析工具(6)软件生命周期可分为定义阶段,开发阶段和维护阶段。详细设计属于A)定义阶段B)开发阶段C)维护阶段D)上述三个阶段(7)数据库管理系统中负责数据模式定义的语言是A)数据定义语言B)数据管理语言C)数据操纵语言D)数据控制语言(8)在学生管理的关系数据库中,存取一个学生信息的
3、数据单位是A)文件B)数据库C)字段D)记录(9)数据库设计中,用E-R图来描述信息结构但不涉及信息在计算机中的表示,它属于数据库设计的A)需求分析阶段B)逻辑设计一阶段C)概念设计阶段D)物理设计阶段(1 0)有两个关系R和T如下:KA B :C 人 B J .a il i 2 1 S-2I.-*-I-则由关系K得到关系T的操作是A)选择B)投影C)交D)并(1 1)以下叙述正确的是A)C语言程序是由过程和函数组成的B)C语言函数可以嵌套调用,例如:f u n(f u n(x)C)C语言函数不可以单独编译D)C语言中除了 m a i n函数,其他函数不可作为单独文件形式存在(1 2)以下关于
4、C语言的叙述中正确的是A)C语言中的注释不可以夹在变量名或关键字的中间B)C语言中的变量可以在使用之前的任何位置进行定义C)在C语言算术表达式的书写中,运算符两侧的运算数类型必须一致D)C语言的数值常量中夹带空格不影响常量值的正确表示(13)以下C语言用户标识符中,不合法的是A),lB)A a BcC)a _ bD)a b(14)若有定义:d o u b l e a=22;i n t i=0,k=18;,则不符合C语言规定的赋值语句是A)a=a+,i+;B)i=(a+k)=(i+k);C)i=a;D)i=!a;(15)有以下程序#i n c l u d em a i n()c h a r a,
5、b,c,d;s c a n f(t 4%c%c,&a,&b);c=g e t c h a r();d=g e t c h a r();printf(44%c%c%c%cn,a,b,c,d);I当执行程序时,按下列方式输入数据(从第1列开始,代表回车,注意:回车也是一个字符)1234则输出结果是A)1234B)12C)123D)1234(16)以 i 关于C 语言数据类型使用的叙述中错误的是A)若要准确无误差的表示自然数,应使用整数类型B)若要保存带有多位小数的数据,应使用双精度类型C)若要处理如“人员信息”等含有不同类型的相关数据,应自定义结构体类型D)若只处理“真”和“假”两种逻辑值,应使用
6、逻辑类型(17)若 a 是数值类型,则逻辑表达式(a=l)ll(a!=l)的值是A)1B)0C)2D)不知道a 的值,不能确定(18)以下选项中与if(a=l)a=b;else a+;语句功能不同的switch语句是A)switch(a)case:a=b;break;default:a+;)B)switch(a=l)case O:a=b;break;case l:a+;)C)switch(a)default:a+;break;case l:a=b;)D)switch(a=l)case 1 :a=b;break;case 0:a+;)(19)有如下嵌套的if语句if(aif(aelse k=c;
7、elseif(belse k=c;以下选项中与上述if语句等价的语句是A)k=(aB)k=(ac)?b:c);C)k=(aD)k=(a(20)有以下程序#includemain()in i,j,m=l;for(i=l;iO;j-)if(i*j)3)break;m=i*j;)printf(nm=%dn,m);)程序运行后的输出结果是A)m=6B)m=2C)m=4D)m=5(21)有以下程序#include(stdio.hmain()int a=l;b=2;for(;a8;a+)b+=a;a+=2;printf(%d,%dn,a,b);)程序运行后的输出结果是A)9,18B)8,11C)7,11D
8、)10,14(22)有以下程序,其中k 的初值为八进制数#includemain()int k=011;primf(dn,k+);)程序运行后的输出结果是A)12B)llC)10D)9(23)下列语句组中,正确的是A)char*s;s=,Olympict;B)char s7;s=,Olympicn;C)char*s;s=Olympic;D)char s7J;s=Olympic;(24)以下关于return语句的叙述中正确的是A)一个自定义函数中必须有一条return语句B)一个自定义函数中可以根据不同情况设置多条return语句C)定义成void类型的函数中可以有带返回值的return语句D)
9、没有return语句的自定义函数在执行结束时不能返回到调用处(25)下列选项中,能正确定义数组的语句是A)int num0.2008;B)int num;C)int N=2008;int numfN;D)#define N 2008int numfN;(26)有以下程序#includevoid fun(char*c,int d)*c=*c+l;d=d+l;printf(%c,%c,*c,d);main()char b=,a,a=A,;fun(&b,a);printf(%e,%en,b,a);程序运行后的输出结果是A)b,B,b,AB)b,B,B,AC)a,B,B,aD)a,B,a,B(27)若
10、有定义int(*Pt)3;,则下列说法正确的是A)定义了基类型为int的三个指针变量B)定义了基类型为int的具有三个元素的指针数组ptC)定义了一个名为*pt、具有三个元素的整型数组D)定义了一个名为p t的指针变量,它可以指向每行有三个整数元素的二维数组(28)设有定义double a10,*s=a;,以下能够代表数组元素a3的是A)(*s)3JB)*(s+3)C)*s3D)*s+3(29)有以下程序#i n c l u d e(s t d i o.h)m a i n()i n t a 5=l,2,3,4,5 ,b 5=0,2,1,3,0 ,i,s=0;f o r(i=0;i 5;i+)s
11、=s+a b i );p r i n t f(n%d nn,s);)程序运行后的输出结果是A)6B)10C)l lD)15(30)有以下程序#i n c l u d em a i n()i n t b 3 3=O,l,2,0,l,2,O,l,2),i,j,t=l;f o r(i=0;i 3;i+)f o r(j=i j=l;j+)t+=b i f b f j i l;p r i n t f(n%d nH,t);)程序运行后的输出结果是A)1B)3C)4D)9(31)若有以下定义和语句c h a r s i l l 0J=na b c d!u,*s 2=n 12 3 W;p r i n t f(
12、%d%d nH,s t r l e n(s 1),s t r l e n(s 2);则输出结果是A)5 5B)1 0 5C)1 0 7D)5 8(32)有以下程序#i n c l u d e#d e f i n e N 8v o i d f u n(i n t *x,i n t i)*x=*(x+i);m a i n()i n t a N=1,2,3,4,5,678 ,i;f u n(a,2);f o r(i=O;i p r i n t f(”d”,a i );p r i n t f(nH);)程序运行后的输出结果是A)1313B)2234C)3234D)1234(33)有以下程序#i n c
13、 l u d ei n t f(i n t t ,i n t n);m a i n i n t a 4=l,2,3,4),s;s=f(a,4);p r i n t f(%d n,s);1i n t f(i n t t ,i n t n)i f(n 0)r e t u r n t n-l +f(t,n-l);e l s e r e t u r n 0;)程序运行后的输出结果是A)4B)1 OC)14D)6(34)有以下程序#i n c l u d ei n t f u n()s t a t i c i n t x=1;x*2;r e t u r n x;)m a i n()i n t i,s=l
14、,f o r(i=l;i year=1980;D)w.s.year=1980;(39)有以下程序#includemain()int a=2,b=2,c=2;pri ntf(n%dnn,a/b&c);)程序运行后的输出结果是A)OB)1C)2D)3(40)有以下程序#includemain()FILE*fp;char str10;fp=fopen(,myfile.dat,wM);fputs(abc,fp);fclose(fp);fpfopen(,myfile.datau;,a4-+n);fprintf(fp,M%dn,28);rewind(fp);fscanf(fp/%s,str);puts(s
15、tr);fclose(fp);)程序运行后的输出结果是A)abcB)28cC)abc28D)因类型不致而出错二、填空题(1)一个队列的初始状态为空。现将元素A,B,C,D,E,F,5,4,3,2,1依次入队,然后再依次退队,则元素退队的顺序为【1】。(2)设某循环队列的容量为5 0,如果头指针fronl=45(指向队头元素的前一位置),尾指针rear=10(指向队尾元素),则该循环队列中共有12】个元素。(3)设二叉树如下:对该二叉树进行后序遍历的结果为【3】。(4)软 件 是【4】、数据和文档的集合。(5)有一个学生选课的关系,其中学生的关系模式为:学生(学号,姓名,班级,年龄),课程的关系
16、模式为:课程(课号,课程名,学时),其中两个关系模式的键分别是学号和课号,则关系模式选课可定义为:选课(学号,5,成绩)。(6)设x为i n t型变量,请写出一个关系表达式【6】,用以判断x同时为3和7的倍数时,关系表达式的值为真。(7)有以下程序#i n cl u dem ai n()i n t a=l,b=2,c=3,d=0;i f(a=l)i f(b!=2)i f(c=3)d=l;el s e d=2;el s e i f(c!=3)d=3;el s e d=4;el s e d=5;p ri n t f C*%d n,d);)程序运行后的输出结果是 7】。(8)有以下程序#i n cl
17、 u dem ai n()i n t m,n;s can f(%d%d,&m,&n);wh i l e(m!=n)wh i l e(m n)m=m-n;wh i l e(mp ri n t f(d n ,m);程序运行后,当输入1 4 63 V回车 时,输 出 结 果 是 8】。(9)有以下程序#i n cl u demain()intij,a3=1,23,4,5,6,7,8,9);for(i=0;i3;i+)for(j=i;j3;j+)printfC%d%,aij);printfCXn1);)程序运行后的输出结果是9】。(10)有以下程序#includemain()int a=l,2,3,4
18、,5,6),*k3,i=0;while(i3)ki=&a2*i;printf(H%dn,*ki);i+;)程序运行后的输出结果是10 o(11)有以下程序#includemain()int a33=l,2,3,4,5,6,7,8,9);intb3=0,i;for(i=0;i3;i+)bi=ai2+a2i;for(i=0;i0;i-)strij=strli-l;str01=temp;)main()char s50J;scanf(n%s,s);fun(s);printf(%sn,s);程序运行后输入:abcdefv回车,则 输 出 结 果 是 1 2 。(13)以下程序的功能是:将值为三位正整数的
19、变量x 中的数值按照个位、十位、百位的顺序拆分并输出。请填空。#includemain()int x=256;printf(H%d-%d-%dnn,13,x/10,x/100);)(14)以下程序用以删除字符串所有的空格,请填空。#includemain()char s100=0ur teacher teach C language!;int i,j;for(i=j=O;si!=,O,;i+)if(si!=,)sj=si;j+;s|j=【14printf(%sn”,s);)(15)以下程序的功能是:借助指针变量找出数组元素中的最大值及其元素的下标值。请填空。#includemain()int
20、a10,*p,*s;for(p=a;p-a10;p+)scanf(n%dn,p);for(p=a,s=a;p-a*s)s=1 5 ;printf(44index=%dn,s-a);2009年 9 月全国计算机等级考试二级笔试试卷C语言程序设计(考试时间90分钟,满 分 100分)一、选 择 题(1)(10)、(21)(40)每题 2 分,(11)(20)每题 1 分,共 70分)(1)下列数据结构中,属于非线性结构的是A)循环队列B)带链队列0二叉树D)带链栈(2)下列数据结果中,能够按照“先进后出”原则存取数据的是A)循环队列B)栈C)队列D)二叉树(3)对于循环队列,下列叙述中正确的是A)
21、队头指针是固定不变的B)队头指针一定大于队尾指针C)队头指针一定小于队尾指针D)队头指针可以大于队尾指针,也可以小于队尾指针(4)算法的空间复杂度是指A)算法在执行过程中所需要的计算机存储空间B)算法所处理的数据量C)算法程序中的语句或指令条数D)算法在执行过程中所需要的临时工作单元数(5)软件设计中划分模块的一个准则是A)低内聚低耦合B)高内聚低耦合0 低内聚高耦合D)高内聚高耦合(6)下列选项中不属于结构化程序设计原则的是A)可封装D)自顶向下0 模块化D)逐步求精A)N-S 图B)P AD 图0 程序流程图D)E-R 图(8)数据库管理系统是A)操作系统的一部分B)在操作系统支持下的系统
22、软件0 一种编译系统D)一种操作系统(9)在 E-R图中,用来表示实体联系的图形是A)椭圆图B)矩形0 菱形D)三角形A)选择B)投影0 交D)并(1 1)以下叙述中正确的是A)程序设计的任务就是编写程序代码并上机调试B)程序设计的任务就是确定所用数据结构C)程序设计的任务就是确定所用算法D)以上三种说法都不完整(1 2)以下选项中,能用作用户标识符的是A)v o i dB)8 _ 8C)_ 0 _D)u n s i gn e d(1 3)阅读以下程序S i n c l u d em a i n ()i n t c a s e;f l o a t p r i n t F;p r i n t f
23、 (“请输入2 个数:”);s c a n f(%d%f”,&c a s e,&p j r i n t F);p r i n t f (a%d%f nw,c a s e,p r i n t F);)该程序编译时产生错误,其出错原因是A)定义语句出错,c a s e 是关键字,不能用作用户自定义标识符B)定义语句出错,p r i n t F 不能用作用户自定义标识符C)定义语句无错,s c a n f 不能作为输入函数使用D)定义语句无错,p r i n t f 不能输出c a s e 的值(1 4)表达式:(i n t)(d o u b l e)9/2)-(9)%2 的值是A)0B)3C)4D
24、)5(1 5)若有定义语句:i n t x=1 0;,则表达式x-=x+x 的值为A)-2 0B)-1 0C)0D)1 0(1 6)有以下程序#i n c l u d em a i n()i n t a=l,b=0;p r i n t f(%d,,b=a+b);p r i n t f (%d n,a=2*b);)程序运行后的输出结果是A)0,0B)1,0C)3,2D)1,21 7)设有定义:i n t a=l,b=2,c=3;,以下语句中执行效果与其它三个不同的是A)i f(a b)c=a,a=b,b=c;B)i f(a b)c=a,a=b,b=c;C)i f(a b)c=a;a=b;b=c;
25、D)i f(a b)c=a;a=b;b=c;(1 8)有以下程序 i n c l u d em a i n()i n t c=0,k;f o r (k=l;k b?(b c?l:O):O;功能相同的是A)i f(a b)&(b c)k=l;e l s e k=0;B)i f(a b)|(b c)k=l;e l s e k=0;C)i f(a=b)k=0;e l s e i f(b b)k=l;e l s e i f (b c)k=l;e l s e k=0;2 0)有以下程序#i n c l u d em a i n()c h a r s =r t0 1 2 x yw ;i n t i,n=0
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 历年 全国计算机 二级 语言
限制150内