资源描述
全国计算机二级C语言2012年3月笔试真题一、选择题在下列各题的A)、B)、C)、D)四个选项中,只有一个选项是正确的,请将正确的选项涂写在答题卡相应位置上,答在试卷上不得分(1)为了避免流程图在描述程序逻辑时的灵活性,提出了用方框图来代替传统的程序流程图,通常也把这种图称为A)PAD图B)N-S图C)结构图D)数据流图(2)结构化程序设计主要强调的是A)程序的规模B)程序的效率C)程序设计语言的先进性D)程序易读性(3)为了使模块尽可能独立,要求A)模块的内聚程度要尽量高,且各模块间的耦合程度要尽量强B)模块的内聚程度要尽量高,且各模块间的耦合程度要尽量弱C)模块的内聚程度要尽量低,且各模块间的耦合程度要尽量弱D)模块的内聚程度要尽量低,且各模块间的耦合程度要尽量强(4)需求分析阶段的任务是确定A)软件开发方法B)软件开发工具C)软件开发费用D)软件系统功能(5)算法的有穷性是指A)算法程序的运行时间是有限的B)算法程序所处理的数据量是有限的C)算法程序的长度是有限的D)算法只能被有限的用户使用(6)对长度为n的线性表排序,在最坏情况下,比较次数不是n(n-1)/2的排序方法是A)快速排序B)冒泡排序C)直接插入排序D)堆排序(7)如果进栈序列为e1,e2,e3,e4,则可能的出栈序列是A)e3,e1,e4,e2B)e2,e4,e3,e1C)e3,e4,e1,e2D)任意顺序(8)将E-R图转换到关系模式时,实体与联系都可以表示成A)属性B)关系C)键D)域(9)有三个关系R、S和T如下:RBCDa0k1b1n1SBCDf3h2a0k1n2x1TBCDa0k1由关系R和S通过运算得到关系T,则所使用的运算为A)并B)自然连接C)笛卡尔积D)交(10)下列有关数据库的描述,正确的是A)数据处理是将信息转化为数据的过程B)数据的物理独立性是指当数据的逻辑结构改变时,数据的存储结构不变C)关系中的每一列称为元组,一个元组就是一个字段D)如果一个关系中的属性或属性组并非该关系的关键字,但它是另一个关系的关键字,则称其为本关系的外关键字(11)以下叙述中正确的是A)用C程序实现的算法必须要有输入和输出操作B)用C程序实现的算法可以没有输出但必须要有输入C)用C程序实现的算法可以没有输入但必须要有输出D)用C程序实现的算法可以既没有输入也没有输出(12)下列可用于C语言用户标识符的一组是A)void,define,WORDB)a3_3,_123,CarC)For,-abc,IFCaseD)2a,DO,sizeof(13)以下选项中可作为C语言合法常量的是A)-80B)-080C)-8e1.0D)-80.0e(14)若有语句:char*line5;,以下叙述中正确的是A)定义line是一个数组,每个数组元素是一个基类型为char为指针变量B)定义line是一个指针变量,该变量可以指向一个长度为5的字符型数组C)定义line是一个指针数组,语句中的*号称为间址运算符D)定义line是一个指向字符型函数的指针(15)以下定义语句中正确的是A)inta=b=0;B)charA=65+1,b=b;C)floata=1,*b=&a,*c=&b;D)doublea=00;b=1.1;(16)有以下程序段charch;intk;ch=a;k=12;printf(%c,%d,ch,ch,k);printf(k=%dn,k);已知字符a的ASCII码值为97,则执行上述程序段后输出结果是A)因变量类型与格式描述符的类型不匹配输出无定值B)输出项与格式描述符个数不符,输出为零值或不定值C)a,97,12k=12D)a,97,k=12(17)有以下程序main()inti,s=1;for(i=1;i=2&c=2&c=2&cb)a=b;c=a;if(c!=a)c=b;printf(%d,%d,%dn,a,b,c);其输出结果是A)程序段有语法错B)3,5,3C)3,5,5D)3,5,7(20)有以下程序#includemain()intx=1,y=0,a=0,b=0;switch(x)case1:switch(y)case0:a+;break;case1:b+;break;case2:a+;b+;break;case3:a+;b+;printf(a=%d,b=%dn,a,b);程序的运行结果是A)a=1,b=0B)a=2,b=2C)a=1,b=1D)a=2,b=1(21)下列程序的输出结果是#includestdio.hmain()inti,a=0,b=0;for(i=1;i10;i+)if(i%2=0)a+;continue;b+;printf(a=%d,b=%d,a,b);A)a=4,b=4B)a=4,b=5C)a=5,b=4D)a=5,b=5(22)已知#intt=0;while(t=1).则以下叙述正确的是A)循环控制表达式的值为0B)循环控制表达式的值为1C)循环控制表达式不合法D)以上说法都不对(23)下面程序的输出结果是main()inta10=1,2,3,4,5,6,7,8,9,10,*p=a;printf(%dn,*(p+2);A)3B)4C)1D)2(24)以下错误的定义语句是A)intx3=0,1,1,2,3;B)intx43=1,2,3,1,2,3,1,2,3,1,2,3;C)intx4=1,2,3,1,2,3,1,2,3,1,2,3;D)intx3=1,2,3,4;(25)有以下程序voidss(char*s,chart)while(*s)if(*s=t)*s=t-a+A;s+;main()charstr1100=abcddfefdbd,c=d;ss(str1,c);printf(%sn,str1);程序运行后的输出结果是A)ABCDDEFEDBDB)abcDDfefDbDC)abcAAfefAbAD)Abcddfefdbd(26)有如下程序main()charch25=6937,8254,*p2;inti,j,s=0;for(i=0;i2;i+)pi=chi;for(i=0;i0;j+=2)s=10*s+pij-0;printf(%dn,s);该程序的输出结果是A)69825B)63825C)6385D)693825(27)有定义语句:chars10;,若要从终端给s输入5个字符,错误的输入语句是A)gets(&s0);B)scanf(%s,s+1);C)gets(s);D)scanf(%s,s1);(28)以下叙述中错误的是A)在程序中凡是以#开始的语句行都是预处理命令行B)预处理命令行的最后不能以分号表示结束C)#defineMAX是合法的宏定义命令行D)C程序对预处理命令行的处理是在程序执行的过程中进行的(29)设有以下说明语句typedefstructintn;charch8;PER;则下面叙述中正确的是A)PER是结构体变量名B)PER是结构体类型名C)typedefstruct是结构体类型D)struct是结构体类型名(30)以下叙述中错误的是A)gets函数用于从终端读入字符串B)getchar函数用于从磁盘文件读入字符C)fputs函数用于把字符串输出到文件D)fwrite函数用于以二进制形式输出数据到文件(31)以下能正确定义一维数组的选项是A)inta5=0,1,2,3,4,5;B)chara=0,1,2,3,4,5,0;C)chara=A,B,C;D)inta5=0123;(32)有以下程序#includemain()charp=a,b,c,q10=a,b,c;printf(%d%dn,strlen(p),strlen(q);以下叙述中正确的是A)在给p和q数组置初值时,系统会自动添加字符串结束符,故输出的长度都为3B)由于p数组中没有字符串结束符,长度不能确定,但q数组中字符串长度为3C)由于q数组中没有字符串结束符,长度不能确定,但p数组中字符串长度为3D)由于p和q数组中都没有字符串结束符,故长度都不能确定(33)有以下程序#include#includevoidfun(char*s,intn)char*t;inti,j;for(i=0;in-1;i+)for(j=i+1;jstrlen(sj)t=si;si:sj;sj=t;main()char*ss=bcc,bbcc,xy,aaaacc,aabcc;fun(ss,5);printf(%s,%sn,ss0,ss4);程序的运行结果是A)xy,aaaaccB)aaaacc,xyC)bcc,aabccD)aabcc,bcc(34)有以下程序#includeintf(intx)inty;if(x=0|x=1)return(3);y=x*x-f(x-2);returny;main()intz;z=f(3);printf(%dn,z);程序的运行结果是A)0B)9C)6D)8(35)下面程序段的运行结果是charstr=ABC,*p=str;printf(%dn,*(p+3);A)67B)0C)字符C的地址D)字符C(36)若有以下定义:structlinkintdata;structlink*next;a,b,c,*p,*q;且变量a和b之间已有如下图所示的链表结构:指针p指向变量a,q指向变量c则能够把c插入到a和b之间并形成新的链表的语句组是:A)a.next=c;c.next=b;B)p.next=q;q.next=p.next;C)p-next=&c;q-next=p-next;D)(*p).next=q;(*q).next=&b;(37)对于下述程序,在方式串分别采用wt和wb运行时,两次生成的文件TEST的长度分别是#includevoidmain()FILE*fp=fopen(TEST,);fputc(A,fp);fputc(n,fp);fputc(B,fp);fputc(n,fp);fputc(C,fp);fclose(fp);A)7字节、7字节B)7字节、5字节C)5字节、7字节D)5字节、5字节(38)变量a中的数据用二进制表示的形式是01011101,变量b中的数据用二进制表示的形式是11110000若要求将a的高4位取反,低4位不变,所要执行的运算是A)abB)a|bC)a&bD)a4(39)下面的程序段运行后,输出结果是inti,j,x=0;staticinta88;for(i=0;i3;i+)for(j=0;j3;j+)aij=2*i+j;for(i=0;i8;i+)x+=aij;printf(%d,x);A)9B)不确定值C)0D)18(40)下列程序执行后的输出结果是voidfunc(int*a,intb)b0=*a+6;main()inta,b5;a=0;b0=3;func(&a,b);printf(%dn,b0);A)6B)7C)8D)9二、填空题请将每一个空的正确答案写在答题卡序号的横线上,答在试卷上不给分(1)测试的目的是暴露错误,评价程序的可靠性;而【1】的目的是发现错误的位置并改正错误(2)某二叉树中度为2的结点有18个,则该二叉树中有【2】个叶子结点(3)当循环队列非空且队尾指针等于队头指针时,说明循环队列已满,不能进行入队运算这种情况称为【3】(4)在关系模型中,把数据看成一个二维表,每一个二维表称为一个【4】(5)在计算机软件系统的体系结构中,数据库管理系统位于用户和【5】之间(6)以下程序的输出结果是【6】main()charc=z;printf(%c,c-25);(7)阅读下面语句,则程序的执行结果是【7】#includestdio.hmain()inta=-1,b=1,k;if(+a0)&!(b-4)printf(%dn,i);break;printf(%dn,i+);(9)以下程序的定义语句中,x1的初值是【9】,程序运行后输出的内容是【10】#includemain()intx=1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,*p4,i;for(i=0;i4;i+)pi=&x2*i+1;printf(%d,pi0);printf(n);)(10)以下程序的输出结果是【11】#includevoidswap(int*a,int*b)int*t;t=a;a=b;b=t;main()inti=3,j=5,*p=&i,*q=&j;swap(p,q);printf(%d%dN,*p,*q)(11)以下程序的输出结果是【12】main()chars=ABCD,*p;for(p=s+1;ps+4;p+)printf(%sn,p);(12)以下程序的输出结果是【13】floatfun(intx,inty)return(x+y);main()inta=2,b=5,c=8;printf(%3.0fn,fun(int)fun(a+c,b),a-c);(13)有如下图所示的双链表结构,请根据图示完成结构体的定义:lheaddatarchildstructaaintdata;【14】node;(14)fseek函数的正确调用形式是【15】
展开阅读全文