




已阅读5页,还剩19页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
2010年3月全国计算机二级C语言笔试试题+答案一、选择题在下列各题的A)、B)、C)、D)四个选项中,只有一个选项是正确的,请将正确的选项涂写在答题卡相应位置上,答在试卷上不得分。(1)下列叙述中正确的是A)对长度为n的有序链表进行查找,最坏情况下需要的比较次数为nB)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(n2)C)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(log2n)D)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(nlog2n)(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)维护阶段 D)上述三个阶段(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)交 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)若有定义:double a=22;int i=0,k=18;,则不符合C语言规定的赋值语句是A)a=a+,i+; B)i=(a+k)=(i+k);C)i=a%11; D)i=!a;(15)有以下程序#includemain()char a,b,c,d; scanf(%c%c,&a,&b); c=getchar();d=getchar(); printf(%c%c%c%cn,a,b,c,d);当执行程序时,按下列方式输入数据(从第1列开始,代表回车,注意,回车也是一个字符)1234则输出结果是A)1234 B)12 C)12 D)12 3 34(16)以下关于C语言数据类型使用的叙述中错误的是A)若要准确无误差地表示自然数,应使用整数类型B)若要保存带有多位小数的数据,应使用双精度类型C)若要处理如人员信息等含有不同类型的相关数据,应自定义结构体类型D)若只处理真和假两种逻辑值,应使用逻辑类型(17)若a是数值类型,则逻辑表达式(a=1)|(a!=1)的值是A)1 B)0C)2 D)不知道a的值,不能确定(18)以下选项中与if(a=1)a=b;else a+;语句功能不同的switch语句是A)switch(a) case 1:a=b;break; default:a+;B)switch(a=1)case 0:a=b;break; case 1:a+;C)switch(a)default:a+;break;case 1:a=b;D)switch(a=1)case 1:a=b;break; case 0:a+;(19)有如下嵌套的if语句if(ab)if(ac)k=a;elsek=c;elseif(bc)k=b;elsek=c;以下选项中与上述if语句等价的语句是A)k=(ab)?a:b;k=(bc)?b:c;B)k=(ab)?(bc)?b:c);C)k=(ab)?(ac)?a:c):(bc)?b:c);D)k=(ab)?a:b;k=(ac)?a:c;(20)有以下程序#includemain()int i,j,m=1; for(i=1;i0;j-)if(i*j3)break;m*=i*j; printf(m=%dn,m);程序运行后的输出结果是A)m=6 B)m=2 C)m=4 D)m=5(21)有以下程序#includemain()int a=1,b=2; for(;a8;a+)b+=a;a+=2; printf(%d,%dn,a,b);程序运行后的输出结果是A)9,18 B)8,11 C)7,11 D)10,14(22)有以下程序,其中k的初值为八进制数#includemain()int k=011; printf(%dn,k+);程序运行后的输出结果是A)12 B)11 C)10 D)9(23)下列语句组中,正确的是A)char *s;s=Olympic; B)char s7;s=Olympic;C)char *s;s=Olympic; D)char s7;s=Olympic;(24)以下关于return语句的叙述中正确的是A)一个自定义函数中必须有一条return语句B)一个自定义函数中可以根据不同情况设置多条return语句C)定义成void类型的函数中可以有带返回值的return语句D)没有return语句的自定义函数在执行结束时不能返回到调用处(25)下列选项中,能正确定义数组的语句是A)int num0.2008; B)int num;C)int N=2008; D)#define N 2008 int numN; int numN;(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,%cn,b,a);程序运行后的输出结果是A)b,B,b,A B)b,B,B,AC)a,B,B,a D)a,B,a,B(27)若有定义int(*pt)3;,则下列说法正确的是A)定义了基类型为int的三个指针变量B)定义了基类型为int的具有三个元素的指针数组ptC)定义了一个名为*pt、具有三个元素的整型数组D)定义了一个名为pt的指针变量,它可以指向每行有三个整数元素的二维数组(28)设有定义double a10,*s=a;,以下能够代表数组元素a3的是A)(*s)3 B)*(s+3)C)*s3 D)*s+3(29)有以下程序#includemain()int a5=1,2,3,4,5,b5=0,2,1,3,0,i,s=0; for(i=0;15;i+) s=s+abi; printf(%dn,s);程序运行后的输出结果是A)6 B)10 C)11 D)15(30)有以下程序#includemain()int b33=0,1,2,0,1,2,0,1,2,i,j,t=1; for(i=0;i3;i+)for(j=1;j=1;j+) t+=bibji; printf(%dn,t);程序运行后的输出结果是A)1 B)3 C)4 D)9(31)若有以下定义和语句char s110=abcd!,*s2=n123;printf(%d %dn,strlen(s1),strlen(s2);则输出结果是A)55 B)105 C)107 D)58(32)有以下程序#include#define N 8void fun(int *x,int i)*x=*(x+i);main()int aN=1,2,3,4,5,6,7,8,i; fun(a,2); for(i=0;iN/2;i+)printf(%d,ai);printf(n);程序运行后的输出结果是A)1 3 1 3 B)2 2 3 4 C)3 2 3 4 D)1 2 3 4(33)有以下程序#includeint f(int t,int n);main()int a4=1,2,3,4,s; s=f(a,4); printf(%dn,s);int f(int t,int n)if(n0) return tn-1+f(t,n-1); else return 0;程序运行后的输出结果是A)4 B)10 C)14 D)6(34)有以下程序#includeint fun()static int x=1; x*=2; return x;main()int i,s=1; for(i=1;i=2;i+) s=fun(); printf(%dn,s);程序运行后的输出结果是A)0 B)1 C)4 D)8(35)有以下程序#include#defineSUB(a)(a)-(a)main()int a=2,b=3,c=5,d; d=SUB(a+b)*c; printf(%dn,d);程序运行后的输出结果是A)0 B)-12 C)-20 D)10(36)设有定义:struct complexint real,unreal; datal=1,8,data2;则以下赋值语句中错误的是A)data2=data1; B)data2=(2,6);C)data2.rea1=data1.real; D)data2.real=datal.unreal;(37)有以下程序#include#includestruct Aint a;char b10;double c;void f(struct A t);main()struct A a=1001,ZhangDa,1098.0; f(a);printf(%d,%s,%6.1fn,a.a,a.b,a.c);void f(struct A t)t.a=1002;strcpy(t.b,ChangRong); t.c=1202.0;程序运行后的输出结果是A)1001,ZhangDa,1098.0 B)1002,ChangRong,1202.0C)1001,ChangRong,1098.0 D)1002,ZhangDa,1202.0(38)有以下定义和语句struct workersint num;char name20;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)有以下程序#includemain()int a=2,b=2,c=2; printf(%dn,a/b&c);程序运行后的输出结果是A)0 B)1 C)2 D)3(40)有以下程序#includemain()FILE *fp;char str10; fp=fopen(myfile.dat,w); fputs(abc,fp);fclose(fp); fp=fopen(myfile.dat,a+); fprintff(fp,%d,28); rewind(fp); fscanf(fp,%s,str);puts(str); fclose(fp);程序运行后的输出结果是A)abc B)28cC)abc28 D)因类型不一致而出错二、填空题请将每一个空的正确答案写在答题卡序号的横线上,答在试卷上不给分。(1)一个队列的初始状态为空。现将元素A,B,C,D,E,F,5,4,3,2,1依次入队,然后再依次退队,则元素退队的顺序为【1】。(2)设某循环队列的容量为50,如果头指针front=45(指向队头元素的前一位置),尾指针rear=10(指向队尾元素),则该循环队列中共有【2】个元素。(3)设二叉树如下:对该二叉树进行后序遍历的结果为【3】。(4)软件是【4】数据和文档的集合。(5)有一个学生选课的关系,其中学生的关系模式为:学生(学号,姓名,班级,年龄),课程的关系模式为:课程(课号,课程名,学时),其中两个关系模式的键分别是学号和课号,则关系模式选课可定义为:选课(学号,【5】,成绩)。(6)设x为int型变量,请写出一个关系表达式【6】,用以判断x同时为3和7的倍数时,关系表达式的值为真。(7)有以下程序#includemain()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(%dn,d);程序运行后的输出结果是【7】。(8)有以下程序#includemain()int m,n; scanf(%d%d,&m,&n); while(m!=n) while(mn)m=m-n; while(mn)n=n-m; printf(%dn,m);程序运行后,当输入1463时,输出结果是【8】。(9)有以下程序#includemain()int i,j,a3=1,2,3,4,5,6,7,8,9; for(i=0;i3;i+)for(j=i;j3;j+)printf(%d,aij); printf(n);程序运行后的输出结果是【9】(10)有以下程序#includemain()int a=1,2,3,4,5,6,*k3,i=0; while(i3) ki=&a2*i;printf(%d,*ki);i+; 程序运行后的输出结果是【10】。(11)有以下程序#includemain()int a33=1,2,3,4,5,6,7,8,9; int b3=0,i; for(i=0;i3;i+) bi=ai2+a2i; for(i=0;i3;i+) printf(%d,bi); printf(n);程序运行后的输出结果是【11】。(12)有以下程序#include#includevoid fun(char *str)char temp;int n,i; n=strlen(str); temp=strn-1; for(i=n-1;i0;i-)stri=stri-1; str0=temp;main()char s50; scanf(%s,s); fun(s); printf(%sn,s);程序运行后输入:abcdef,则输出结果是【12】(13)以下程序的功能是:将值为三位正整数的变量x中的数值按照个位、十位、百位的顺序拆分并输出。请填空。#includemain()int x=256; printf(%d-%d-%dn,【13】,x/10%10,x/100);(14)以下程序用以删除字符串中所有的空格,请填空。#includemain()char s100=our teacher teach c language!;int i,j; for(i=j=0;si!=0;i+)if(si!= )sj=si;j+; sj=【14】; printf(%sn,s);(15)以下程序的功能是:借助指针变量找出数组元素中的最大值及其元素的下标值。请填空。#includemain()int a10,*p,*s; for(p=a;p-a10;p+)scanf(%d,p); for(p=a,s=a;p-a*s) s=【15】; printf(index=%dn,s-a);一、选择题(1)A对长度为n的有序链表进行查找,最坏情况是从最小值开始查找最大值(或从最大值开始查找最小值),这个过程需要比较的次数为n,故选项A正确。对分查找只能针对随机存取的有序表进行,而有序链表只能进行顺序存取,不能进行随机存取,在有序链表上不能进行对分查找,故B、C、D选项都错误。(2)D算法的时间复杂度是指算法需要消耗的时间资源,是独立于机器的,选项D正确;相同的算法在不同的机器上运行时间可能不同,选项A错误;算法所处理的数据量与算法无关,选项B错误;程序的长短与程序执行时需要消耗的时间资源没有必然的关系,比如一个条件语句可以很长,但只需判断一次,而一个循环语句可能只有几行,但可以执行很多次,故选项C错误。(3)B编辑软件、教务管理软件属于应用软件,操作系统属于系统软件,浏览器属于支撑软件,故本题答案选B。(4)A软件调试的任务是诊断和改正程序中的错误,本题正确答案为A。其他三项描述不正确,选项B描述不全面,选项C描述太绝对,选项D描述不符合定义。(5)C数据流图是结构化分析方法中使用的工具,它以图形的方式描绘数据在系统中流动和处理的过程。软件结构图是软件概要设计的工具,而详细设计是对概要设计的每个模块进行细化,UML是面向对象的需求分析的工具。(6)B软件定义阶段的基本任务是确定软件系统的工程需要,分为软件系统的可行性研究和项目需求分析。软件开发阶段包括概要设计、详细设计、实现、组装测试和确认测试5个阶段。维护阶段主要是软件的使用、系统维护和系统更新换代。(7)A数据定义语言用于定义数据库的所有特性和属性,如行布局、列定义、文件位置和存储策略等。(8)D在关系数据表中,行称为元组,对应存储文件中的记录,列称为属性,对应存储文件中的字段,所以本题答案为D。(9)CE-R图即实体-联系图 (Entity-Relation Diagram),用来建立数据模型,在数据库系统概论中属于概念设计阶段。(10)A关系T中的两行和关系R中的最后两行一致,通过选择运算即可由R得到T。(11)BC语言中只有函数没有过程,故选项A错误;C语言可以嵌套调用,故选项B正确;C语言函数可以单独编译成.dll文件,故选项C错误;C语言中除main函数以外,其他函数可作为单独文件形式存在,故选项D也错误。(12)BC语言中注释可以放在任何位置,选项A错误;C语言中的变量只要在使用之前定义即可,位置可以是使用前的任何位置,故选项B正确;C语言中两侧数据类型可以不一致,系统可进行强制类型转换,选项C错误;C语言数值常量中不允许存在空格,选项D错误。(13)D标识符由字母、下划线、数字三个方面组成,开头必须是字母或下划线。(14)CC语言中取余运算符两侧的操作数只能是整型(若为char型,则会自动转换成整型)。(15)C程序根据用户输入分别给字符型变量a、b、c、d赋值为1、2、3,因此输出到屏幕得到选项C中的格式。(16)DC语言中没有逻辑类型,若只处理真或假两种逻辑值,可以使用整型数1或0表示,故选D。(17)A当A=1时,(A=1)|(A!=1)为真;当A!=1时,(A=1)|(A!=1)也为真,故正确答案为A。(18)Bswitch(a=1)语句中,若a等于1,则a=1为真,则应该进行a=b的操作,故选项B错误。(19)C嵌套的if语句功能是将k赋值为a、b、c中的最小值,选项A中没有比较a、c的大小,选项B中语句(bc)?b:c)错误,选项D中没有比较b、c大小。(20)A第一次循环i=1,j=3和j=2时都能执行m*=i*j,此时得到m的值为6;然后进行第二次循环i=2,j=3时会执行break语句,内部循环直接结束,此时i再加1,也会导致退出外部循环,所以最终结果m的值为6。(21)D初始值a=1,b=2,第一次循环:b=b+a=2+1=3,a=a+2=1+2=3,a=a+1=3+1=4;第二次循环:b=b+a=3+4=7,a=a+2=4+2=6,a=a+1=6+1=7;第三次循环:b=b+a=7+7=14,a=a+2=7+2=9,a=a+1=9+1=10,故本题答案选D。(22)D011转换成十进制为9,并且k+表示先使用k的值,再使k的值加1,所以输出值为9。(23)A若s被定义为指针,选项A表示将指针s指向一个字符串,选项C表示为指针s赋一个字符串的值,显然选项A正确,选项C错误;若s被定义为数组,且要为该数组直接赋值,则必须在定义时进行,因此选项B和选项D都错误。(24)B一个自定义函数中可以没有返回值。如果函数不返回值,则应定义为void型,程序执行结束后自动返回到调用处。故选项A、C、D错误。一个自定义函数可以根据不同的情况设置多条return语句,但函数的返回值必须只有一个,故选项B正确。(25)D选项A不符合C语言的语法要求;选项B中没有指定数组的大小;选项C中数组大小不能用变量来指定。(26)A函数fun的第一个参数传指针,可以将更改后的值传回调用函数,第二个参数传值,不能将更改后的值传回调用函数,故选A。(27)D定义了一个指向一维数组的指针,该一维数组具有三个int型元素,按照C语言中二维数组的定义知,二维数组先按照行排列,再按照列排列,故选D。(28)Bs指向数组首元素,s+3表示指针s向后移动3个位置,即数组的第4个元素a3,故选B。(29)C当i=0时ab0=1;当i=1时ab1=3;当i=2时ab2=2;当i=3时ab3=4;当i=4时ab4=1。将以上各数值相加得11,故选C。(30)C当i=0,j=0时能进行相加操作,b0b00=0;当i=1,j=1时能进行相加操作,b1b11=1;当i=2,j=2时能进行相加操作,b2b22=2。将以上各数值相加再加1,得4,故选C。(31)A计算字符串长度是从第一个字符开始到0前的一个字符结束。第一个字符串长度为5,分别为a、b、c、d、!第二个字符串的长度也为5,分别为n,1,2,3,,其中n和均表示一个字符。(32)Cfun函数的功能是把数组下标为i的值赋值给a0,所以执行fun(a,2)后,数组前4个数字为3、2、3、4,故选择C。(33)B函数的功能是求数组所有元素的和。递归表示为a3+a2+a1+a0+f(t,0)=10。(34)Cx被声明为静态变量,第一次调用fun()后,x值为2,第二次调用时直接执行x*=2,值为4。(35)C在此处需要直接替换整个式子,SUB(a+b)*c即为(a+b)-(a+b)*c,代入a,b,c的值可得结果为-20。(36)B选项B需要强制转换数据类型,应该为(struct complex)2,6;。(37)A该函数的调用为传值调用,故不会改变任何值。(38)D结构体structure workers中的成员s是结构体类型,给w中成员year赋值的语句是w.s.year=1980,故选D。(39)A对于a/b&c,先求a/b,得到1,然后求1&c(即按位与操作),显然得0。(40)C首先打开文件写入字符串abc,然后关闭文件,再打开时文件指针定位到了最后
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 四川教师招聘考试代课面试备考策略
- 水库加固施工过程安全管理方案
- 智算中心自动化数据处理方案
- 给水管道腐蚀防护方案
- 项目验收标准与验收流程
- 水库预警与应急排洪系统方案
- 2025年健康管理与促进实践操作考试试题及答案
- 建筑项目施工过程中的消防安全检查方案
- 高级销售人才招募:悉尼面试题及答案解析
- 2025年辽宁省初中学业水平考试考前模拟数学试卷及答案
- DB51-T 3251-2025 煤矿井下应急广播系统使用管理规范
- 静压植桩机钢管桩施工技术
- 高值耗材点评制度
- 防台防汛培训课件教学
- 2024年施工员题库含完整答案(必刷)
- 道路施工流程讲解
- 有限合伙企业合伙协议
- 保险资管合规风险管理-深度研究
- 2022教师民族团结培训
- 《慢阻肺健康大课堂》课件
- 2024人教版英语七年级下册《Unit 3 Keep Fit How do we keep fit》大单元整体教学设计2022课标
评论
0/150
提交评论