無暱稱>试卷(2013/12/29)

计算机等级考试— 二级—《C语言 》題庫 下載題庫

96 年 - 2007年9月计算机等级考试— 二级—《C语言 》#13780 

选择:50题,非选:0题
立即測驗 
我要補題 回報試卷錯誤 試卷下載
1.1)软件是指
(A)程序
(B)程序和文档
(C)算法加数据结构
(D)程序、数据和相关文档的集合
2.2)软件调试的目的是
(A)发现错误
(B)改正错误
(C)改善软件的性能
(D)验证软件的正确性
3.3)在面向对象方法中,实现信息隐蔽是依靠
(A)对象的继承
(B)对象的多态
(C)对象的封装
(D)对象的分类
4.4)下列叙述中,不符合良好程序设计风格的是
(A)程序的效率第一,清晰第二
(B)程序的可读性好
(C)程序中有必要的注释
(D)输入数据前要有提示信息
5.5)下列叙述中正确的是
(A)程序执行的效率与数据的存储结构密切相关
(B)程序执行的效率只取决于程序的控制结构
(C)程序执行的效率只取决于所处理的数据量
(D)以上三种说法都不对
6.6)下列叙述中正确的是
(A)数据的逻辑结构与存储结构必定是一一对应的
(B)由于计算机存储空间是向量式的存储结构,因此,数据的存储结构一定是线性结构
(C)程序设计语言中的数组一般是顺序存储结构,因此,利用数组只能处理线线结构
(D)以上三种说法都不对
7.7)冒泡排序在最坏情况下的比较次数是
(A)nn+1)/2
(B)nlog2n
(C)nn-1)/2
(D)n/2
8.8)一棵二叉树中共有70个叶子结点与80个度为1的结点,则该二叉树中的总结点数为
(A)219
(B)221
(C)229
(D)231
9.9)下列叙述中正确的是
(A)数据库系统是一个独立的系统,不需要操作系统的支持
(B)数据库技术的根本目标是要解决数据的共享问题
(C)数据库管理系统就是数据库系统
(D)以上三种说法都不对
10.10)下列叙述中正确的是
(A)为了建立一个关系,首先要构造数据的逻辑关系
(B)表示关系的二维表中各元组的每一个分量还可以分成若干数据项
(C)一个关系的属性名表称为关系模式
(D)一个关系可以包括多个二维表
11.11)C语言源程序名的后缀是
(A).exe
(B).C
(C).obj
(D).cp
12.12)可在C程序中用做用户标识符的一组标识符是
(A)and
(B)Date
(C)Hi
(D)case_2007y-m-dDr.TomBigl
13.13)以下选项中,合法的一组C语言数值常量是
(A)028
(B)12.
(C).177
(D)0x8A.5e-3OXa234c1.510,000-0xf4.5e0Oabc3.e5
14.14)以下叙述中正确的是
(A)C语言程序将从源程序中第一个函数开始执行
(B)可以在程序中由用户指定任意一个函数作为主函数,程序将从此开始执行
(C)C语言规定必须用main作为主函数名,程序将从此开始执行,在此结束
(D)main可作为用户标识符,用以命名任意一个函数作为主函数
15.15)若在定义语句:inta,b,c,*p=&c;之后,接着执行以下选项中的语句,则能正确执行的语句是
(A)scanf"%d",a,b,c;
(B)scanf"%d%d%d",a,b,c;
(C)scanf"%d",p);
(D)scanf"%d",&p);
16.16)以下关于long、int和short类型数据占用内存大小的叙述中正确的是
(A)均占4个字节
(B)根据数据的大小来决定所占内存的字节数
(C)由用户自己定义
(D)由C语言编译系统决定
17.17)若变量均已正确定义并赋值,以下合法的C语言赋值语句是
(A)x=y==5;
(B)x=n%2.5;
(C)x+n=I;
(D)x=5=4+1;
18.18)有以下程序段 intj;floaty;charname[50]; scanf"%2d%f%s",&j,&y,name);当执行上述程序段,从键盘上输入555667777abc后,y的值为
(A)55566.0
(B)566.0
(C)7777.0
(D)566777.0
19.19)若变量已正确定义,有以下程序段 i=0; doprintf"%d,",i);whilei++); printf"%d ",i)其输出结果是
(A)0,0
(B)0,1
(C)1,1
(D)程序进入无限循环
20.20)有以下计算公式若程序前面已在命令中包含math.h文件,不能够正确计算上述公式的程序段是
(A)ifx>=0)y=sqrtx);
(B)y=sqrtx)elsey=sqrt-x);ifx<0)y=sqrt-x);
(C)ifx>=0)y=sqrtx);
(D)y=sqrtx>=0?x:-x);Ifx<0)y=sqrt-x);
21.21)设有条件表达式:EXP)?i++;j--,则以下表达式中EXP)完全等价的是
(A)EXP==0)
(B)EXP!=0)
(C)EXP==1)
(D)EXP!=1)
22.22)有以下程序 #include main) {inty=9; fory>0;y--) ify%3==0)printf"%d",--y);0}程序的运行结果是
(A)741
(B)963
(C)852
(D)875421
23.23)已有定义:charc;,程序前面已在命令行中包含ctype.h文件,不能用于判断c中的字符是否为大写字母的表达式是
(A)isupperc
(B)’A’<=c<=’Z’
(C)’A’<=c&&c<=’Z’
(D)c<=‘2’-32)&&‘a’-32)<=c
24.24)有以下程序 #include main) {inti,j,m=55; fori=1;i<=3;i++) forj=3;j<=i;j++)m=m%j; printf"%d ",m);}程序的运行结果是
(A)0
(B)1
(C)2
(D)3
25.25)若函数调用时的实参为变量时,以下关于函数形参和实参的叙述中正确的是
(A)函数的实参和其对应的形参共占同一存储单元
(B)形参只是形式上的存在,不占用具体存储单元
(C)同名的实参和形参占同一存储单元
(D)函数的形参和实参分别占用不同的存储单元
26.26)已知字符’A’的ASCⅡ代码值是65,字符变量c1的值是’A’,c2的值是’D’。执行语句printf"%d,%d",c1,c2-2);后,输出结果是
(A)A,B
(B)A,68
(C)65,66
(D)65,68
27.27)以下叙述中错误的是
(A)改变函数形参的值,不会改变对应实参的值
(B)函数可以返回地址值
(C)可以给指针变量赋一个整数作为地址值
(D)当在程序的开头包含文件stdio.h时,可以给指针变量赋NULL
28.28)以下正确的字符串常量是
(A)""
(B)’abc’
(C)OlympicGames
(D)""
29.29)设有定义:charp[]={’1’,’2’,’3’},*q=p;,以下不能计算出一个char型数据所占字节数的表达式是
(A)sizeofp)
(B)sizeofchar)
(C)sizeof*q)
(D)sizeofp[0])
30.30)有以下函数 intaaachar*s) {char*t=s; while*t++); t--; returnt-s);}以下关于aaa函数的功能叙述正确的是
(A)求字符串s的长度
(B)比较两个串的大小
(C)将串s复制到串t
(D)求字符串s所占字节数
31.31)若有定义语句:inta[3][6];,按在内存中的存放顺序,a数组的第10个元素是
(A)a[0][4]
(B)a[1][3]
(C)a[0][3]
(D)a[1][4]
32.32)有以下程序 #include voidfunchar**p) {++p;printf"%s ",*p);} main) {char*a[]={"Morning","Afternoon","Evening","Night"}; fun a;}程序的运行结果是
(A)Afternoon
(B)fternoon
(C)Morning
(D)orning
33.33)若有定义语句:inta[2][3],*p[3];,则以下语句中正确的是
(A)p=a;
(B)p[0]=a;
(C)p[0]=&a[1][2];
(D)p[1]=&a;
34.34)有以下程序 #include voidfunint*a,intn)/*fun函数的功能是将a所指数组元素从大到小排序*/ {intt,i,j; fori=0;i(A)1,2,3,4,5,6,7,8,9,0,
(B)0,9,8,7,6,5,1,2,3,4,
(C)0,9,8,7,6,5,4,3,2,1,
(D)1,2,3,4,9,8,7,6,5,0,
35.35)有以下程序 #include intfunchars[]) {intn=0; while*s<=’9’&&*s>=’0’){n=10*n+*s-’0’;s++;} returnn);} main) {chars[10]={’6’,’1’,’*’,’4’,’*’,’9’,’*’,’0’,’*’}; printf"%d ",funs));}程序运行的结果是
(A)9
(B)61490
(C)61
(D)5
36.36)当用户要求输入的字符串中含有空格时,应使用的输入函数是
(A)scanf)
(B)getchar)
(C)gets)
(D)getc)
37.37)以下关于字符串的叙述中正确的是
(A)C语言中有字符串类型的常量和变量
(B)两个字符串中的字符个数相同时才能进行字符串大小的比较
(C)可以用关系运算符对字符串的大小进行比较
(D)空串一定比空格打头的字符串小
38.38)有以下程序: #include voidfunchar*t,char*s) {while*t!=0)t++; while*t++=*s++)!=0);} main) {charss[10]=”acc”,aa[10]=”bbxxyy”; funss,aa; printf“%s,%s ”,ss,aa;}程序运行结果是
(A)accxyy,bbxxyy
(B)acc,bbxxyy
(C)accxxyy,bbxxyy
(D)accbbxxyy,bbxxyy
39.39)有以下程序 #include #include voidfunchars[][10],intn) {chart;inti,j; fori=0;is[j][0]{t=s[0];s[0]=s[j][0];s[j][0]=t;}} main) {charss[5][10]={“bcc”,”bbcc”,”xy”,”aaaacc””aabcc”} funss,5);printf“%s,%s ”,ss[0],ss[4]);}程序运行结果是
(A)xy,aaaacc
(B)aaaacc,xy
(C)xcc,aabcc
(D)acc,xabcc
40.40)在一个C语言源程序文件中所定义的全局变量,其作用域为:
(A)所在文件的全部范围
(B)所在程序的全部范围
(C)所在函数的全部范围
(D)由具体定义位置和extern说明来决定范围
41.41)有以下程序 #include inta=1; intfint c {staticinta=2; c=c+1; returna++)+c;} main) {inti,k=0; fori=0;i<2;i++){inta=3;k+=fa;} k+=a; printf“%d ”,k);}程序运行结果是
(A)14
(B)15
(C)16
(D)17
42.42)有以下程序 #include voidfunintn,int*p) {intf1,f2; ifn==1||n==2)*p=1; else {funn-1,&f1);funn-2,&f2); *p=f1+f2;}} main) {ints; fun3,&s);printf"%d ",s);}程序的运行结果是
(A)2
(B)3
(C)4
(D)5
43.43)若程序中有宏定义行:#defineN100则以下叙述中正确的是
(A)宏定义行中定义了标识符N的值为整数100
(B)在编译程序对C源程序进行预处理时用100替换标识符N
(C)对C源程序进行编译时用100替换标识
(D)在运行时用100替换标识符N
44.44)以下关于typedef的叙述错误的是
(A)用typedef可以增加新类型
(B)typedef只是将已存在的类型用一个新的名字来代表
(C)用typedef可以为各种类型说明一个新名,但不能用来为变量说明一个新名
(D)用typedef为类型说明一个新名,通常可以增加程序的可读性
45.45)有以下程序 #include structtt {intx;structtt*y;}*p; structtta[4]={20,a+1,15,a+2,30,a+3,17,a}; main) {inti; p=a; fori=1;i<=2;i++){printf"%d,",p->x);p=p->y;}}程序的运行结果是
(A)20,30,
(B)30,17
(C)15,30,
(D)20,15,
46.46)有以下程序 #include #include typedefstruct{charname[9];charsex;floatscore[2];}STU; STUfSTUa {STUb={"Zhao",'m',85.0,90.0};inti; strcpya.name,b.name); a.sex=b.sex; fori=0;i<2;i++)a.score=b.score; returna;} main) {STUc={"Qian",'f',95.0,92.0},d; d=fc;printf"%s,%c,%2.0f,%2.0f ",d.name,d.sex,d.score[0],d.score[1]);}程序的运行结果是
(A)Qian,f,95,92
(B)Qian,m,85,90
(C)Zhao,m,85,90
(D)Zhao,f,95,92
47.47)设有以下定义 uniondata {intd1;floatd2;}demo;则下面叙述中错误的是
(A)变量demo与成员d2所占的内存字节数相同
(B)变量demo中各成员的地址相同
(C)变量demo和各成员的地址相同
(D)若给demo.d1赋99后,demo.d2中的值是99.0
48.48)有以下程序 #include main) {inta=1,b=2,c=3,x; x=a^b&c;printf"%d ",x);}程序的运行结果是
(A)0
(B)1
(C)2
(D)3
49.49)读取二进制文件的函数调用形式为:freadbuffer,size,count,fp);,其中buffer代表的是
(A)一个文件指针,指向待读取的文件
(B)一个整型变量,代表待读取的数据的字节数
(C)一个内存块的首地址,代表读入数据存放的地址
(D)一个内存块的字节数
50.50)有以下程序 #include main) {FILE*fp;inta[10]={1,2,3,0,0},i; fp=fopen"d2.dat,"wb"); fwritea,sizeofint),5,fp); fwritea,sizeofint),5,fp); fclosefp); fp=fopen"d2.dat","rb"); freada,sizeofint),10,fp); fclosefp); fori=0;i<10;i++)printf"%d",a;}程序的运行结果是
(A)1,2,3,0,0,0,0,0,0,0,
(B)1,2,3,1,2,3,0,0,0,0,
(C)123,0,0,0,0,123,0,0,0,0,
(D)1,2,3,0,0,1,2,3,0,0,