全国计算机二级C语言笔试模拟331.docx

上传人:b****7 文档编号:16343286 上传时间:2023-07-12 格式:DOCX 页数:31 大小:39.95KB
下载 相关 举报
全国计算机二级C语言笔试模拟331.docx_第1页
第1页 / 共31页
全国计算机二级C语言笔试模拟331.docx_第2页
第2页 / 共31页
全国计算机二级C语言笔试模拟331.docx_第3页
第3页 / 共31页
全国计算机二级C语言笔试模拟331.docx_第4页
第4页 / 共31页
全国计算机二级C语言笔试模拟331.docx_第5页
第5页 / 共31页
全国计算机二级C语言笔试模拟331.docx_第6页
第6页 / 共31页
全国计算机二级C语言笔试模拟331.docx_第7页
第7页 / 共31页
全国计算机二级C语言笔试模拟331.docx_第8页
第8页 / 共31页
全国计算机二级C语言笔试模拟331.docx_第9页
第9页 / 共31页
全国计算机二级C语言笔试模拟331.docx_第10页
第10页 / 共31页
全国计算机二级C语言笔试模拟331.docx_第11页
第11页 / 共31页
全国计算机二级C语言笔试模拟331.docx_第12页
第12页 / 共31页
全国计算机二级C语言笔试模拟331.docx_第13页
第13页 / 共31页
全国计算机二级C语言笔试模拟331.docx_第14页
第14页 / 共31页
全国计算机二级C语言笔试模拟331.docx_第15页
第15页 / 共31页
全国计算机二级C语言笔试模拟331.docx_第16页
第16页 / 共31页
全国计算机二级C语言笔试模拟331.docx_第17页
第17页 / 共31页
全国计算机二级C语言笔试模拟331.docx_第18页
第18页 / 共31页
全国计算机二级C语言笔试模拟331.docx_第19页
第19页 / 共31页
全国计算机二级C语言笔试模拟331.docx_第20页
第20页 / 共31页
亲,该文档总共31页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

全国计算机二级C语言笔试模拟331.docx

《全国计算机二级C语言笔试模拟331.docx》由会员分享,可在线阅读,更多相关《全国计算机二级C语言笔试模拟331.docx(31页珍藏版)》请在冰点文库上搜索。

全国计算机二级C语言笔试模拟331.docx

全国计算机二级C语言笔试模拟331

二级C语言笔试模拟331

一、选择题

1.软件是指。

A.程序

B.程序和文档

C.算法加数据结构

D.程序、数据和相关文档的集合

答案:

D

[解答]计算机系统由硬件和软件两部分组成。

其中,计算机软件包括程序、数据与相关文档的完整集合。

2.软件调试的目的是。

A.发现错误

B.改正错误

C.改善软件的性能

D.验证软件的正确性

答案:

B

[解答]软件调试的任务是诊断和改正程序中的错误。

3.在面向对象方法中,实现信息隐蔽是依靠。

A.对象的继承

B.对象的多态

C.对象的封装

D.对象的分类

答案:

C

[解答]对象的封装性是指从外部看只能看到对象的外部特征,即只需知道数据的取值范围和可以对该数据施加的操作,而不需要知道数据的具体结构以及实现操作的算法。

4.下列叙述中,不符合良好程序设计风格的是。

A.程序的效率第一,清晰第二

B.程序的可读性好

C.程序中有必要的注释

D.输入数据前要有提示信息

答案:

A

[解答]一般来讲,程序设计风格首先应该简单和清晰,其次程序必须是可以理解的,可以概括为“清晰第一,效率第二”。

5.下列叙述中正确的是。

A.程序执行的效率与数据的存储结构密切相关

B.程序执行的效率只取决于程序的控制结构

C.程序执行的效率只取决于所处理的数据量

D.以上三种说法都不对

答案:

A

[解答]数据的存储结构、程序处理的数据量、程序的算法等都会影响程序执行效率。

6.下列叙述中正确的是。

A.数据的逻辑结构与存储结构必定是一一对应的

B.由于计算机存储空间是向量式的存储结构,因此,数据的存储结构一定是线性结构

C.程序设计语言中的数组一般是顺序存储结构.因此,利用数组只能处理线性结构

D.以上三种说法都不对

答案:

D

[解答]数据的逻辑结构是指反映数据元素之间逻辑关系的数据结构。

数据的存储结构(也称数据的物理结构)是指数据的逻辑结构在计算机存储空间中的存放形式。

通常一种数据的逻辑结构根据需要可以表示成多种存储结构。

7.冒泡排序在最坏情况下的比较次数是。

A.n(n+1)/2

B.nlog2n

C.n(n-1)/2

D.n/2

答案:

C

[解答]对n个结点的线性表采用冒泡排序,在最坏情况下,需要经过n/2次的从前往后的扫描和n/2次的从后往前的扫描,需要的比较次数为n(n-1)/2。

8.一棵二叉树中共有70个叶子结点与80个度为1的结点,则该二叉树中的总结点数为。

A.219

B.221

C.229

D.231

答案:

A

[解答]在任意一棵二叉树中,设度为0的结点(即叶子结点)数为n0,度为2的结点数为n2,则有n0=n2+1,本题中叶子结点的个数为70,所以度为2的结点个数为69,故总结点数=叶子结点数+度为1的结点数+度为2的结点数=70+80+69=219。

9.下列叙述中正确的是。

A.数据库系统是一个独立的系统,不需要操作系统的支持

B.数据库技术的根本目标是要解决数据的共享问题

C.数据库管理系统就是数据库系统

D.以上三种说法都不对

答案:

B

[解答]数据库、数据库管理系统、数据库管理员、硬件平台、软件平台这5部分共同构成了一个以数据库为核心的完整的运行宾体,称为数据库系统。

数据库技术的根本目的是要解决数据的共享问题。

数据库管理系统是一种系统软件,负责数据库中的数据组织、数据操作、数据维护、控制及保护和数据服务等,是数据库系统的核心,它是数据库系统的一部分,二者不能等同。

10.下列叙述中正确的是。

A.为了建立一个关系,首先要构造数据的逻辑关系

B.表示关系的二维表中各元组的每一个分量还可以分成若干数据项

C.一个关系的属性名表称为关系模式

D.一个关系可以包括多个二维表

答案:

A

[解答]元组分量的原子性要求二维表中元组的分量是不可分割的基本数据项。

关系的框架称为关系模式。

一个称为关系的二维表必须同时满足关系的7个性质。

11.C语言源程序名的后缀是。

A..exe

B..c

C..obj

D..cpp

答案:

B

[解答]由C语言构成的指令序列称为C源程序,源程序文件的后缀为.c。

12.可在C程序中用做用户标识符的一组标识符是。

A.and

_2007

B.Date

y-m-d

C.Hi

Dr.Tom

D.case

Bigl

答案:

A

[解答]在C语言中,合法的标识符可以由字母、数字和下画线组成,且第一个字符必须为字母或下画线。

13.以下选项中,合法的一组C语言数值常量是。

A.028

.5e-3

-0xf

B.12.

0Xa23

4.5e0

C..177

4c1.5

0abc

D.0x8A

10.000

3.e5

答案:

B

[解答]C语言中,八进制数其开头必须是数字“0”,其数字包括0~7,因此选项A错误。

浮点数据的指数形式表示中,字母e或E之后的指数必须为整数,所以选项C错误。

选项D中,整型数据10,000的表示形式是错误的。

14.以下叙述中正确的是。

A.C语言程序将从源程序中第一个函数开始执行

B.可以在程序中由用户指定任意一个函数作为主函数,程序将从此开始执行

C.C语言规定必须用main作为主函数名,程序将从此开始执行,在此结束

D.main可作为用户标识符,用以命名任意一个函数作为主函数

答案:

C

[解答]C语言规定必须以main作为主函数名。

程序要从main()函数开始执行,最后在main()函数中结束。

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);

答案:

C

[解答]题中整型指针变量p存放的是变量c的地址。

所以本题答案为C。

16.以下关于long、int和short类型数据占用内存大小的叙述中正确的是。

A.均占4字节

B.根据数据的大小来决定所占内存的字节数

C.由用户自己定义

D.由C语言编译系统决定

答案:

D

[解答]几类整型数所占用的字节数因编译系统或计算机系统的规定不同而有所差异。

17.若变量均已正确定义并赋值,以下合法的C语言赋值语句是。

A.x=y==5;

B.x=n%2.5;

C.x+n=i:

D.x=5=4+1;

答案:

A

[解答]求余运算符“%”两侧的运算对象都应当是整型数据,所以选项B错误。

因为赋值运算符左侧的操作数必须是一个变量,所以选项C和D是错误的。

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

答案:

B

[解答]变量j只接收输入数据的前两位,从第三位开始直到空格之间的输入整数都会被保存到浮点型变量y中。

19.若变量已正确定义,有以下程序段

i=0;

doprintf("%d,",i);while(i++);

printf("%d",i)

其输出结果是。

A.0,0

B.0,1

C.1,1

D.程序进入无限循环

答案:

B

[解答]本题中,变量i的初始值等于0,执行循环体中的语句后,输出i的值为0。

while后面括号中表达式i++的值为0,循环结束。

此时变量i自加1,所以再次加“1”。

20.有以下计算公式

若程序前面已在命令中包含math.h文件,不能够正确计算上述公式的程序段是。

A.if(x>=0)y=sqrt(x);

elsey=sqrt(-x);

B.y=sqrt(x)

if(x<0)y=sqrt(-x);

C.if(x>=0)y=sqrt(x);

if(x<0)y=sqrt(-x);

D.y=sqrt(x>0?

x:

-x);

答案:

B

[解答]选项A、C、D分别用一个ifelse语句、两个if语句和条件表达式表达了计算公式的含义。

21.设有条件表达式:

(EXP)?

i++;j--,则以下表达式中(EXP)完全等价的是。

A.(EXP==0)

B.(EXP!

=0)

C.(EXP==1)

D.(EXP!

=1)

答案:

B

[解答]本题中,当表达式EXP不等于0时条件成立,执行语句“i++;”,当EXP等于0时,执行语句“j--;”,等同于条件表达式“(EXP!

=0)?

i++:

j--;”。

22.有以下程序

#include<stdio.h>

main()

{inty=9;

for(y>0;y--)

if(y%3==0)printf("%d",--y);

}

程序的运行结果是。

A.741

B.963

C.852

D.875421

答案:

C

[解答]在for循环中,当y的值为9、6或3时,执行输出语句,输出表达式--y的值。

y先自减1,然后再输出y的值。

23.已有定义“charc;”,程序前面已在命令行中包含ctype.h文件,不能用于判断c中的字符是否为大写字母的表达式是。

A.isupper(c)

B.'A'<-c<='Z'

C.'A'<=c&&c<='Z'

D.c<=('z'-32)&&('a'-32)<=c

答案:

B

[解答]选项B先计算关系表达式“'A'<=c”的值是0还是1,再比较该值与字符'z'之间的大小关系,不能实现题目所要求的功能。

24.有以下程序

#include<stdio.h>

main()

{inti,j,m=55;

for(i=1;i<=3;i++)

for(j=3;j<=i;j++)m=m%j;

printf("%d",m);

}

程序的运行结果是。

A.0

B.1

C.2

D.3

答案:

B

[解答]内层循环条件要求“j<=i”,因此只有当i和j都等于3时循环才会执行一次。

因此m的值为55对3求余,结果为1。

25.若函数调用时的实参为变量时,以下关于函数形参和实参的叙述中正确的是。

A.函数的实参和其对应的形参共占同一存储单元

B.形参只是形式上的存在,不占用具体存储单元

C.同名的实参和形参占同一存储单元

D.函数的形参和实参分别占用不同的存储单元

答案:

D

[解答]在C语言中,函数的实参单元与形参单元在内存中分配不同的存储单元。

26.已知字符'A'的ASCII代码值是65,字符变量c1的值是'A',c2的值是'D'。

执行语句printf("%d,%d",c1,c2-2);后,输出结果是。

A.A,B

B.A,68

C.65,66

D.65,68

答案:

C

[解答]在C语言中,用整型格式输出字符时,输出的是其ASCII码值。

27.以下叙述中错误的是。

A.改变函数形参的值,不会改变对应实参的值

B.函数可以返回地址值

C.可以给指针变量赋一个整数作为地址值

D.当在程序的开头包含文件stdio.h时,可以给指针变量赋NULL

答案:

C

[解答]指针变量的值只能是存储单元地址,而不能是一个整数,故选项C错误。

28.以下正确的字符串常量是。

A."\\\"

B.'abc'

C.OlympicGames

D.""

答案:

D

[解答]选项A中“\\\”为转义字符,故选项A错误,选项B和C显然不是字符串常量。

选项D是一个字符串常量,称为空串。

29.设有定义:

charp[]={'1','2','3'},*q=p;,以下不能计算出一个char型数据所占字节数的表达式是。

A.sizeof(p)

B.sizeof(char)

C.sizeof(*q)

D.sizeof(p[0])

答案:

A

[解答]选项A计算的是p[]字符数组首地址所占的内存字节数。

选项B、C和D都能计算出一个字符型数据所占的字节数。

30.有以下函数

intaaa(char*s)

{char*t=s;

while(*t++);

t--;

return(t-s);

}

以下关于aaa函数的功能叙述正确的是。

A.求字符串s的长度

B.比较两个串的大小

C.将串s复制到串t

D.求字符串s所占字节数

答案:

A

[解答]在while循环开始前,指针t和s都指向字符串的起始位置。

while循环的判断条件中,判断t所指位置是否为字符串的结束标志,同时让t右移一位。

当while循环结束时,t自减1,此时t指向的位置是字符串的结束标志,故t-s的值是字符串的长度。

31.若有定义语句“inta[3][6];”,按在内存中的存放顺序,a数组的第10个元素是。

A.a[0][4]

B.a[1][3]

C.a[0][3]

D.a[1][4]

答案:

B

[解答]在C语言中数组的下标是从0开始,且二维数组元素的存储是按行存放的。

32.有以下程序

#include<stdio.h>

voidfun(char**p)

{++p;printf("%s",*p);}

main()

{char*a[]={"Morning","Afternoon","Evening","Night");

fun(a):

}

程序的运行结果是。

A.Afternoon

B.fternoon

C.Morning

D.orning

答案:

A

[解答]执行fun(a)语句时,p指向的是字符串数组a的第一个字符串”Morning”,p自加1之后,p指向字符串数组a的第2个字符串“Afternoon”。

33.若有定义语句:

inta[2][3],*p[3];,则以下语句中正确的是。

A.p=a;

B.p[0]=a;

C.p[0]=&a[1][2];

D.p[1]=&a;

答案:

B

[解答]选项B表示把整型数组a[0]的指针赋给p[0]。

34.有以下程序

#include<stdio.h>

voidfun(int*a,intn)/*fun函数的功能是将a所指数组元素从大到小排序*/

{intt,i,j;

for(i=0;i<n-1;j++)

for(j=i+1;j<n;j++)

if(a[i]<a[j]){t=a[i];a[i]=a[j];a[j]=t;)

}

main()

{intc[10]={1,2,3,4,5,6,7,8,9,0},i;

fun(c+4,6);

for(i=0;i<10;i++)printf("%d,",c[i]);

printf("\n");

}

程序运行的结果是。

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,

答案:

D

[解答]fun()函数的功能是对数组a[]的元素从大到小进行排序。

35.有以下程序

#include<stdio.h>

intfun(chars[])

{intn=0:

while(*s<='9'&&*s>='0'){n=10*n+*s-'0';s++;}

return(n):

}

main()

{chars[10]={'6','1','*','4','*','9','*','0','*'};

printf("%d",fun(s));

}

程序运行的结果是。

A.9

B.61490

C.61

D.5

答案:

C

[解答]在fun函数中,while循环的功能是逐个取字符数组s的字符判断其是否是数字,若是则将这些数字组成一个数保存到变量n中,并返回变量n的值。

36.当用户要求输入的字符串中含有空格时,应使用的输入函数是。

A.scanf()

B.getchar()

C.gets()

D.getc()

答案:

C

[解答]gets()函数用来从终端键盘读入字符串(包括空格符),直到读入一个换行符为止。

37.以下关于字符串的叙述中正确的是。

A.C语言中有字符串类型的常量和变量

B.两个字符串中的字符个数相同时才能进行字符串大小的比较

C.可以用关系运算符对字符串的大小进行比较

D.空串一定比空格打头的字符串小

答案:

D

[解答]字符串常量是由双引号括起来的一串字符,所以A选项错误。

任意两个字符串的大小比较要调用字符串比较函数strcrop(s1,s2)来进行,所以选项B和C错误。

38.有以下程序

#include<stdio.h>

voidfun(char*t,char*s)

{while(*t!

=0)t++;

while((*t++=*s++)!

=0);

}

main()

{charss[10]="ace",aa[10]="bbxxyy";

fun(ss,aa);printf("%s,%s",ss,aa);

}

程序运行结果是。

A.acexyy,bbxxyy

B.ace,bbxxyy

C.accxxyy,bbxxyy

D.accbbxxyy,bbxxyy

答案:

D

[解答]主函数中语句fun(ss,aa)的功能是将字符串aa连接到字符串ss的末尾。

39.有以下程序

#include<stdio.h>

#include<string.h>

voidfun(chars[][10],intn)

{

chart;inti,j;

for(i=0;i<n-1;i++)

for(j=i+1,j<n;j++)

/*比较字符串的首字符大小,并交换字符串的首字符*/

if(s[0])>s[j][0]{t=s[i][0];s[i][0]=s[j][0];s[j][0]=t;}

}

main()

{charss[5][10]={"bcc","bbcc","xy","aaaaec","aabcc"}

fun(ss,5);printf("%s,%s",ss[0],ss[4]);

}

程序运行结果是。

A.xy,aaaacc

B.aaaacc,xy

C.XCC,aabcc

D.acc,xabcc

答案:

D

[解答]函数.fun(chars[][10],intn)比较二维字符数组s[][10]的每个字符串的首字符大小,如果前一个字符串首字符大于后一个字符串的首字符,则交换这两个字符串的首字符。

40.在一个C语言源程序文件中所定义的全局变量,其作用域为。

A.所在文件的全部范围

B.所在程序的全部范围

C.所在函数的全部范围

D.由具体定义位置和extern说明来决定范围

答案:

D

[解答]全局变量是在函数外部任意位置上定义的变量,它的作用域是从变量定义的位置开始.到整个源文件结束止。

当全局变量定义在后,引用它的函数在前时,应该在引用它的函数中用extern对此全局变量进行说明,以便通知编译程序该变量是一个已在外部定义了的全局变量,这时全局变量的作用域从extern说明处起,延伸到该函数末尾。

41.有以下程序

#include<stdio.h>

inta=1:

intf(intc)

{staticinta=2;

c=c+1:

return(a++)+c;

}

main()

{inti,k=0;

for(i=0;i<2;i++)(inta==3;k+=f(a);}

k+=a;

printf("%d\n",k);

}

程序运行结果是。

A.14

B.15

C.16

D.17

答案:

A

[解答]在主函数中,k的初值为0,首先调用函数f(3),返回值为6,k的值变为6,而函数intfun(intc)中的局部静态变量a等于3。

第二次调用函数f(3)时,返回值为7,所以k=6+7=13。

退出循环语句,k再加上全局变量a的值1,其最终的值为14。

42.有以下程序

#include<stdio.h>

voidfun(intn,int*p)

{intf1,f2;

if(n==1||n==2)*p=1;

else

{fun(n=1,&f1);fun(n-2,&f2);

*p=f1+f2;

}

}

main()

{ints;

fun(3,&,s);printf("%d",s);

}

程序的运行结果是。

A.2

B.3

C.4

D.E

答案:

A

[解答]在函数fun中对参数n的值进行判断,如果其值等于1或2,则*p=1,否则,函数fun进行递归调用fun(n.1,&f1);fun(n.2,&f2);*p=n+f2;在主函数调用fun函数时传递给参数n的值为3,fun函数又递归用了两次自身fun(2,&n);fun(1,&f1);所以n和f2的值都为1,通过指针p的引用,变量s的值为2。

43.若程序中有宏定义行“#defineN100”,则以下叙述中正确的是。

A.宏定义行中定义了标识符N的值为整数100

B.在编译程序对C源程序进行预处理时用100替换标识符N

C.对C源程序进行编译时用100替换标识符N

D.在运行时用100替换标识符N

答案:

B

[解答]C语言中,凡是以“#”号开头的行,都称为“编译预处理”。

对C源程序进行编译前,由编译预处理程序对这些编译预处理命令进行处理。

44.以下关于typedef的叙述错误的是。

A.用typedef可以增加新类型

B.typedef只是将已存在的类型用一个新的名字来代表

C.用typedef可以为各种

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 解决方案 > 学习计划

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2