新视野二级C语言笔试习题集参考答案解析

新视野二级C语言笔试习题集参考答案解析
新视野二级C语言笔试习题集参考答案解析

C语言基础知识

一,选择题

1 答案是A

A正确

B {}可以作为复合语句的标志

C main 函数不是用户命名的

D 分号是语句结束的标志,肯定是语句的一部分

做这个题目需要对书上的概念透彻的理解

2 答案是A

A 错误用户标识符:命名时,标识符的选择由用户自定,但是不能与

关键字相同,所以A选项错误。这个题目考察用户标识符

3 答案是B

用户标识符是标识符,所以可以是有下划线,但是中划线不属于字母,

数字,下划线其中一种。这个题目考察用户标识符的概念。

4 答案是B

define 是预定义标识符,而预定义标识符可以是用户标识符,所以 define可以是用户标识,if 是关键字,而关键字不能是用户标识符,所以if不可以是用户标识符

5 答案是D

long 是关键字,参照附录二

注:6--13 考察用户标识符概念

6 答案是D

D答案以数字2开头了,不符合标识符定义

7 答案是C

C答案以数字开头了

8 答案是D

int 是关键字

9 答案是B

答案A 是关键字,答案C是以数字开头了,不符合概念,答案D出

现了小数点

10 答案是A

答案A出现了小数点

11 答案是C

答案C 以数字开头了

12 答案是A

B答案中float 是关键字,C答案中3c以数字3开头了,D答案中-5d 中 - 不属于字母,数字,下划线中一种

13 答案是A

B答案中-max中-错误,C答案中3COM以字母3开头了,D答案中

int 是关键字,不是用户标识符

14 答案是B

A答案中15. 后面不应该有点,C答案中出现了逗号,D中字母B有问题

15 答案是D

Visual C++6.0中int类型的变量占的字节数为4。

16 答案是B

B中出现了8,而八进制只能有0到7组成

17 答案是D

答案D中开头是0不是o

18 答案是C

答案A中E后面是整数,0.5是小数

答案B 中E后面不能为空

答案D中E前面不能为空

本题目考察指数的表示形式

19 答案是C

答案A中2.0有问题,不能为小数形式

答案B中E前面不能为空

答案D中E后面不能为空

本题目考察指数的表示形式

20 答案是A

B中八进制中不能出现数字8,C中e后面不能是小数,D中e后面不能为空

21 答案是B

B中0.4是小数,不正确

22 答案是C

C中0.5是小数,不正确

23 答案是D

3.6-5/2+1.2+5%2=3.6-2+1.2+1=3.8

本题目考察算术运算符,需要注意整数除以整数结果只能是整数

24 答案是D

%不能用于实型的计算

25 答案是D

D答案中$不属于字母,数字,下划线

26 答案是 A

A答案是逗号表达式,B答案中x+1=y是赋值表达式,左边只能是变量,而这里是x+1, 同理答案C中x+10也是错误的,在D答案中,

考察的是强制类型转换,

正确的是(double)x/10

27 答案是 A

本题考察的是注释需要注意的地方,具体解答见课本第2页中间部分

28 答案是B

答案A中n2没有定义,答案C中在定义f之前不能使用它,答案D

中E后面必须是整数

29 答案是 C

考察的是强制类型转换,正确的是k%(int)f

30 答案是 D

本题目类似与第七课时的例一,解题方法是要抓住++m,--n,--m,

表达式的值是变量变化之后的值,而n--表达式的值是变量n变化之

前的值

31 答案是B

本题目考察的是负

整数与无符号正整数在计算机中存放的格式的一样的,但表示的不

同的两个数

32 答案是C

A答案中%运算对象不能为实型,26.8错误,B答案中考察的赋值运算符,赋值运算符左边必须是变量,所以赋值运算符左边1+2错

误,同理答案D错误

33 答案是 C

本题目考察的是课本第15页的关于自加与自减运算符的第一点说

明,即增量运算符的运算对象只能是变量,而在C答案中++(i+1)

中,i+1是表达式

34 答案是 B

本题目考察的是整数除以整数结果是整数,在B答案中1/2结果是0,

导致整个表达式的值是0,明显是错误的

35 答案是D

对于++、--单目运算符来说,其运算对象可以是char型、int型和

float型变量

36 答案是A

本题目主要考察n++表达式的值是n变化之前的值,然后使n的值

增加1

37 答案是 B

c=a/b+0.4 c=8/5+0.4 c=1+0.4 c=1.4 因为c 是int 型的,所以c的值是1 ,做此题目需要仔细阅读题目

38 答案是 D

(int)a+b/b=(int)5.5+2.5/2.5=5+1.000000=b=6.000000

同样a,b的类型是double型的

39 答案是D

long 和short不能相互修饰

40 答案是 C

标识符中不能有$

41答案是C

A选项中,在变量赋值时不能赋给表达式,而y*5是表达式;选项B

中进行强制类型转换时,类型标识符要加上括号,所以错误;选项D

中,%(求余运算符)运算对象只能是整形数。

42 答案是 A

选项A中,b变量还没有定义

43 答案是C

选项A中long是关键字;选项B中“-”符号不属于字母、数字或

下划线;选项D中,int是关键字。

44 答案是 B

选项A中,八进制数只能由0—7之间的数字组成;选项C,十六进

制数应该以0X开头,并且由0—9以及a—f组成,Oabc不正确;选

项D中10,000包含逗号,不正确。

45 答案是B

C语言的标识符中只能包含字线、数字和下划线,没有连接符。

46 答案是 C

既然在存中,字符数据以 ASCII 码存储,它的存储形式就与整数的

存储形式类似。这样使字符型数据和整型数据之间可以通用。一个

字符数据既可以以字符形式输出,也可以以整数形式输出。以字符

形式输出时,需要先将存储单元中的 ASCII 码转换成相应字符,然

后输出。以整数形式输出时,直接将 ASCII 码作为整数输出。也可

以对字符数据进行算术运算,此时相当于对它们的 ASCII 码进行算

术运算。

47 答案是D

不同的计算机系统或者编译系统,对3种整数类型所占用的字节数

有不同的规定。

48 答案是A

选项B中求余运算(%)的运算对象必须是整型;选项C中,赋值运

算符(=)的左边必须是变量,不能是常量或表达式;选项D与选项

C同理。

49 答案是 A

++运算符有前缀和后缀两种形式,本题中的选项C就是前缀形式,其表达式的值为增1后的值,而选项A为后缀形式,其表达式的值

为增1之前的值。而选项B和D的表达式都是k加1之后的值

50 答案是A

51 答案是C

选项A中将一个变量j的值赋给了一个表达式,这种写法是错误的,

只能给变量赋值,而不能给常量和表达式赋值;选项B中强制类型

转换的格式使用出错,强制类型转换时,类型标识符必须用括号括

起来;选项D中,求余运算符(%)的两端必须是整形数。

52 答案是 D

字符常量是用单引号括起来的单个字符,所以选项B错误;此外还

有一种特殊的字符专为控制设计,称为转义字符,有三种转义字符:

一种是由一个“\”开头加一个普通字符组成,代表一个字符。如’

\’’表示一个单引号字符,所以选项D正确;’\\’表示一个斜杠字

符,而选项C中的’\’则是错误的;用“\”与其后的1~3位八进

制数字构成的字符序列,表示ASCII码等值于该八进制数的字符;

用“\x”与其后的1~2位十六进制数字构成的字符序列,表示ASCII

码等值于该十六进制数的字符;所以选项A错误。

53 答案是B

字符常量是用单引号括起来的单个字符,所以选项A正确;此外还

有一种特殊的字符专为控制设计,称为转义字符,有三种转义字符:

一种是由一个“\”开头加一个普通字符组成,代表一个字符。如’

\n’表示一个换行符,所以选项D正确;用“\”与其后的1~3位八

进制数字构成的字符序列,表示ASCII码等值于该八进制数的字符,

所以选项B错误,因为9不是八进制数字;用“\x”与其后的1~2

位十六进制数字构成的字符序列,表示ASCII码等值于该十六进制

数的字符;所以选项C正确。

54 答案是D

大写字母的ASCII码值比小写字母的ASCII码值小32

55 答案是 A

选项A中的字符变量ch只能接收单个字符,‘ab’不是单个字符,

所以错误。

56 答案是B

char x=’C’将一个大写字母赋给了字符型变量x;然后通过x=x+32

将x中字符的ASCII码值加32,即为小写字符’c’的ASCII码值;

然后将x以字符形式输出,即为小写字母c。

57 答案是A

语句char x,y;定义两个字符型变量x,y;然后通过x=’B’-‘A’

+’a’将用大写字母B的ASCII码送去大写字母A的ASCII码,结

果便为1,然后再加上小写字每a的AS CII码,结果就为小写字母

b的ASCII码,然后再赋值给变量x;通过y=x+2,将变量x中的ASCII

码值加2,即变成小写字母d的ASCII码值再赋值给变量y;然后以

数值形式输出变量x中的ASCII码值为98,再以字符形式输出变量

y中的字符为d。

58 答案是B

选项A中字符’0’的ASCII码值为48,所以A的结果不为1;选项

B中’\0’代表空值,空值NULL的ASCII码值为0所以结果为1;

选项C中字符’1’的ASCII码值为49,所以结果不为1;选项D相

当于用0-48结果也不为1。

59 答案是 D

如果要表示十六进制字符,则要用’\x’开头,所以选项A错误;

如果要表示八进制,则’\0’开头,后面跟1~3位的八进制数,八

进制数由0~7组成,不包含8,所以选项B错误;用单引号括起来的

单个字符才是字符常量,所以C错误;而’\n’是转义字符,用来

表示回车符。

60 答案是B

用单引号括起来的单个字符,称为字符常量,所以选项B错误。

61 答案是C

先将c1 变量中的字符的ASCII码值输出,即为65,将变量c2中字

符的ASCII码值减2后输出,即为66。

62 答案是 A

我们知道异或运算,只有两个操作数不同,结果才为1。所以0^1=1,

1^1=0,由此可推理,任何数与1进行异或运算都得它的相反数;变

量b中的高4位为1,所以要让变量a的高4位取反,即可让变量a

和变量b进行异或运算。

63 答案是A

变量c1和c2中的值相同,所以转换成二进制数后,对应的二进制

位上的值也相同,当两值相同时,只有进行异或运算,结果才为0,

所以c1^c2值为0。所以本题的正确答案为A。

64 答案是A

4|3转换成对应的二进制数即100|011=111再转换为十进制数即为

7;而4&3转换成对应的二进制数即100&011=000,再转换为十进制

数即为0;所以选择A。

65 答案是 D

x/y的值为1,z的值也为1,1和1求反进行与运算,结果一定为0。

所以本题选择D。

66 答案是D

2+x=00000010+10100111=10101001;~3=~00000011=11111100;所以

就相当于10101001^11111100=01010101,所以选择D。

67 答案是 D

a=0x3转换为二进制数即为00000011;b=a|0x8转换为二进制数即为

00000011|00001000=00001011即b=11,b<<1即

00001011<<1=00010110即c=22,所以本题选择D。

二,填空题

1 位 0 1

2 关键字预定义标识符用户标识符

3 8

4 八十十六

5 int float double

6 5+3.6/2=5+1.8=6.8

7 15 16 a++表达式的值是a变化之前的值,当然a本身增加了1

8 把10赋给变量B

9 123.46

(int)(x*100+0.5)/100.0=(int)(12345.67+0.5)/100.0=(int)(1234

6.17)/100.0=12346/100.0=123.46。

10 3

整个表达式是一个逗号表达式,变量n和i赋值为2后,通过++i

将i的值增加1变为3,然后再通过i++为i增加1,整个逗号表达

式的值为i++的值,此时是后缀,所以整个i++表达式的值为3,而

变量i的值为2。

11 11110111

第11题没有详细解析而且答案出错:

~x^y<<1=~00000010^00000101<<1=11111101^00001010=11110111 12 2

只有’\\’和’\b’是正确的

13 2 20.000000

x=f*=n/=(c=50)是一个赋值表达式,它的顺序是从右向左赋值,先

执行c=50,然后执行n/=50即n=n/50=100/50=2,接着执行f*=2即

f=f*2=10*2=20.000000,最后再将值赋给变量x。输出变量n和x

的值,即为2 20.000000。

14 a=14

表达式a=(3*5,a+4)的括号中是一个逗号表达式,其结果是最后一个

表达式的值,即将a+4=14的值赋给变量a。所以输出结果为a=14。

第二章顺序结构

一选择题

1,答案是 C

随意使用空语句会导致逻辑上出现错误,不要随便使用。

2,答案是 B

语句必须以分号结尾,A,C,D表达式后面均没有分号。

3,答案是 C

int x=13,y=4;说明x,y均为整型,所以x/y只取整数部分(舍去法),值为3,把3赋值给x,整个x=x/y表达式的值为左边变量x的值,所以输出为3。

4,答案是 A

a,b均为整型,a/b是取a÷b所得商的整数部分,所以是0,再把0赋值给 c,所以是c的值是0。

5,答案是 D

A 注释语句可以放在代码的任何位置

B 将r定义为整型不会在编译时出错,会自动进行类型转换

C 变量s为浮点型,格式描述符%f时正确的

D π是非法的变量

6,答案是 D

(x,y)是逗号表达式,它的值只有一个,所以格式说明符的个数和输出项的个数是相等的。并且逗号表达式的值为最后一个表达式的值,最后一个表达式是y=2003,所以整个表达式的值是2003,因此输出值为2003。

7,答案是 A

m是十进制整数以十进制有符号的形式输出,即照原样输32767,n=032767,

032767是八进制的整数以八进制无符号形式输出,去掉前面的0。见教材P34

8,答案是 C

m,n的值都是十六进制数0xabc,m-=n即是m=m-n, 把m-n的值赋给m,即把0赋给m,再把m值以十六进制无符号的形式输出,输出的十六进制

数不用在前面0x或者0X。见教材P35

9,答案是 B

表达式i--的值是在变量自减之前的值,i的初值为10,所以该表达式的值也为10;表达式j++的值是变量自加之后的值,j初值为1,所以该表达

式在值是2。

10,答案是 C

m=0256,即m是八进制的数0256,要以八进制无符号的形式输出,即输出 256;n=256,即n是十进制的数256,也要以八进制无符号的形式输出,首先要把十进制数转化为八进制数,256转化为八进制为0400,以无符号形式输出,即输出400。

11,答案是 B

在printf语句中,格式控制的个数只有一个,即%d,而输出项有两项,即a和b。而得到的结果应该只有一个,所以应该输出第一个变量的值,即变量a的值。

12,答案是 C

第一个数据的输出控制宽度是2位,但是x的值是102,占3位,要输出的数据宽度大于规定的输出宽度,所以按数据的实际宽度输出,输出102。

第二个数据要求以十进制形式输出,输出控制宽度是2,y的值为012,是八进制数,所以要转换成十进制数10后再输出。

13, 答案是 B

表达式a=f/=c*=(x=6.5),按从右到左结合,先把6.5赋值给x,再执行c =c*6.5,c的值变为65,再执行f=f/65,为浮点数的除法,f的值为

1.53……,再把f的值赋给a,a为整型数据,执行强制类型转换,a的值

为1。a对应的输出格式为%d,即输出1;c对应的输出格式为%d,输出65,f对应的输出格式%3.1f,即输出控制宽度为3位,保留小数点后一位小数,即输出1.5,x对应的输出格式也为%3.1f,输出6.5。

14,答案是 D

float x=-123.456;说明x为单精度浮点数据,单精度浮点数据对应的输出格式应该为%f。

15,答案是 C

m=(k+=i*=k);按从右到左结合,先执行i=i*k;即i被赋值为4,再执行k =k+4;k被赋值为6,最后把6赋给m,输出m和i的值。

16,答案是 C

略(参考12题)

17,答案是 D

-m++遵循从右向左结合的原则;m++的值为m自增之前的值,所以执行完x=-m++以后,x被赋值为-3;表达式x=x+8/++n中有加号除号,先算8/++n,++n的值为自增之后的值为5,8/5取整为1,即x=x+8/++n 转化为x=x+1,即把x+1的值赋给x,x的值变为-2。

18,答案是 D

A 输入函数应为scanf();

B,C 输入数据列表必须是地址表达式;

19,答案是 A

从键盘输入数据的格式必须与输入控制要求的格式一样

B答案三个之间不要有空格;C答案用逗号分开是多余的;D答案格式不匹配。

20,答案是 A

格式控制要求输入的两个数据之间要用逗号隔开,A没有逗号所以错误,D 两个输入数之间的回车换行可以忽略。

21,答案是 C

x乘以100是为了把x小数点后的两位小数变为整数,再加上0.5,如果小数点后一位大于等于5则会进一位,如果小数点后一位小于5则不会出现进位的情况,再对其进行强制类型转换,采用舍去法丢掉小数部分,即对x乘上100后的数实现了小数位到整数位的四舍五入。最后再除以100.0,把数字变回原来的大小,整数与浮点数相除结果为浮点数,即实现了要求。

22,答案是 C

从键盘输入数据的格式必须与输入控制要求的格式一样。

23,答案是 B

输入控制中第一个数要求以“%2d”形式输入,即要求输入一个两位的数,而从键盘输入的数为876,所以从左到右取两位数字87,即把87赋值给整型变量a,余下的6再赋值给浮点型变量b,自动进行类型转换,b的值为6.000000,后面输入的543则没有赋值给变量。

24,答案是 D

“%%”会输出一个“%”,“d”会照原样输出,因为没有格式说明,m,n 无法输出到屏幕。

25,答案是 D

第1个输出语句要求ch以%c(字符)形式输出所以为输出“a”,以%d(整数)形式输出为,字符转换为整型要使用ASCII码所以为“97”,k没有对应的输出符所以没有输出,第2个输出语句要求以整型方式输出k得到“12”。结果为“a,97,k=12”

26,答案是 B

a+b的结果为30,按照“a+b=%d\n”的输出格式得到输出结果“a+b=30”

B

27,答案是 B

printf可以没有输出项,没有输出项的printf只是没有输出容;整数不能以十二进制输出,getchar()只能读入字符。

28,答案是 A

getchar()可以读入空格符合回车符。

二填空题

1,一条语句分号

2, 88

首先将八进制数0210转化为十六进制的数0X88,输出格式说明要以十六进制无符号的形式输出,所以省略0X,直接输出88。

3, 11

把十进制数转化为八进制数,以无符号的形式输出

4, 25 21 37

b为八进制数025,c为十六进制数0X25,首先把b、c都转化为十进制的整数,分别为21、37,按照输出格式要求a、b、c以十进制整数形式输出,中间以空格分开,所以输出为25 21 37。

5, n1=%d\nn2=%d

除了n1,n2的值之外,还必须加入“n1=”“n2=”照原样输出的字符,很明显在两个数据之间还加了换行符。

6, i=10,j=20<回车>

格式控制中加入了格式说明以外的其他字符,则在输入数据时这些字符也要同样输入。输入格式控制为i=%d,j=%d,所以则应该从键盘输入i=10,j=20

7, 261

a为十进制数177转化为八进制的数为0261,以无符号的形式输出为261

8,16

a的初值为0,在表达式a+=(a=8)中,a首先被赋值为8,再执行操作a=a +a,所以a最后被赋值为16,即输出a的值为16

9,printf(“a=%d,b=%d”, a, b);

10, B 66

B在ASCII码中派在A的后面A为65,那么B为66。

11,10

012为八进制数,转换为十进制为10。

12,12 34

在scanf函数中指定了宽度为2,输入123456,a=12,b=34,后面的567无效。

13,12

程序运行时输入12,getchar()函数只能接受单个字符,所以ch1=’1’,ch2=’2’。

n1=ch1-‘0,转化为ASCII码计算n1=50-49,n1的值为1。n2=n1*10+(ch2-‘0’)转化为ASCII码计算n2 = 1*10+(51-49),n2的值为12。

第三章选择结构

一、选择题

1、D 此题主要是考语句的特征。一条语句只包含一个分号,D项有两个分号,

应该是两条语句,所以选D。

2、C此题主要是考真假条件的等价。题目中的E为非0时条件为真,为0时为

假。那么把非0和0带到选项中可知,C项正好是E为0时表达式为真,非0时为假,所以选C。

3、D 任意合法的表达式都可以作为逻辑运算符的运算对象

4、D 此题主要是考逻辑运算和关系运算的优先级别.只要掌握!、算术运算和&&

的优先级别便可选对.这几种运算符的具体优先级关系见见教材P188,附录

三。

5、A 此题主要是考逻辑运算符!、&&和||之间的优先级别。!最高,&&次之,||

最低。先求得!a为0,所以不必计算!b的值,即!a&&!b的值为0,由c=0,!c=1,而0||1=1,所以选A。

6、A 此题主要是考了逻辑、关系和算术运算,熟练掌握逻辑运算、关系运算和

算术运算的优先级别后,就不难了。A 选项中!a为0,所以!a==1为假,那么就不用计算&&后面的表达式了,因为0与任何数均为假;B项中先计算出a

7、D 此题考到了++运算符以及逻辑运算。当计算机碰到a&&b时,先计算表达式

a的值,若为真才会计算表达式b的值,否则将不会去计算b的值,因为一旦a=0,则0&&b必为0;而a||b则正好是相反的,即先计算表达式a的值,若a为假才会计算表达式b的值,否则将不会去计算b的值,因为一旦a=1,则1||b的值必为1,理解了这两点后,我们在看题目:i++==1的值为1,此时i为2,所以计算&&后的表达式,首先计算++j==3的值为1,j的值为3,由上面的原理我们可知,||后面的表达式不用再计算,所以此时i,j,k的值分别为2,3,3。

8、D 此题和题2非常的相似,也是考真假条件的转换,其中D项中只有k为0

时,!k%2==1才成立,显然和A、B、C三项不同。

9、C 此题主要是考if和else的配对问题。见教材P51。

10、D 此题主要是考if和else的一般形式。if后面的语句要么是单条语句,

要么是由{ }扩起来的复合语句,不能是if后有两条语句的,所以本题程序在运行的时候会出错。

11、C 此题考到了关系运算和逻辑运算及一定数学知识。|x-y|<10可等价为

-10

将-10

12、D 此题也是考到了真假条件的变换和if-else语句。A、B、C三项都是表示

a为真时输出x,为假时输出y,而D则是a为假时输出x,为真时输出y。

13、D 此题考查了赋值表达式的一般格式,=的左边是变量名,右边是表达式,

所以D项错误。

14、C 此题主要是考查逻辑运算符||,当计算机碰到a||b, 先计算表达式a的值,

若为假才会计算表达式b的值,否则将不会去计算b的值,因为一旦a=1,则0||b必为0。题中b>a为真,所以(n=b>a)为1,那么将不会去计算m=a

的值,k被并赋值1,所以m依然为0 。

15、C 此题主要是考查if-else-if和if语句。具体分析见教材第49页例7。

16、C此题主要是考查if-else-if以及关系表达式的运算。首先判断第一个条

件a>b>c的值为0,所以不执行第一条语句;在判断第二个条件,c-1>=c 表达式的结果为假,所以也不执行其下面的语句,因此执行最后一条语句,将输出d+2的值为4 。

17、C 此题主要是考查条件表达式和条件运算符。首先要注意条件表达式的结合

方向,它是从右至左的(可参照附录三)第一个条件表达式的值为a,第二个条件表达式的值为c ,而c=6,所以答案选C

18、A此题主要是考查if-else语句和条件表达式的转化。只要理解了if-else

语句和条件表达式的运算规则的话,就很容易选出A

19、D 此题主要是考查在switch语句中break和default的作用及break的适

用围。详细说明可参看教材第三章 P53对switch的说明部分。

20、B

此题考查的是条件表达式求解问题。先看第一个条件表达式语句,ac为假,所以k=k=2选 B

21、A

此题考查的是条件表达式的求解顺序。参照附录三可知,它的结合方向是自右至左,所以先求得右边一个条件表达式的值为2,再求得左边一个的值为1,即选A

22、C

此题考查的是真假条件的等价问题。x-y为真表示x-y是非0的,也即x-y<0或x-y>0 即选C

23 答案是B

C语言的字符以其ASCII码的形式存在,所以要确定某个字符是大写字母,只要确定它的ASCII码在’A’和’Z’之间就可以了,选项A和C符合要求。

大写字母的ASCII码值的围为65到90,所以D选项符合要求,所以只有C 是错误的。

24 答案是B

满足表达式(c>=2&&c<=6)的整型变量c的值是2,3,4,5,6。当变量c 的值不为2,4,6时,其值只能为3或5,所以表达式c!=3和c!=5中至少有一个为真,即不论c为何值,B选项中的表达式的值都为真,所以B选项正确。

25 答案是A

条件x==0||x==1为真,所以执行y=1,然后执行

y=x*x-(x-2)*(x-2)=1-(-1)*(-1)=1-1=0,所以选择A。

26 答案是B

当表达式EXP为非0值时条件成立,即执行语句i++;当EXP等于0时执行语句j--;。这就等同于条件表达式“(EXP!=0)?i++:j—”。所以本题选择B。

27 答案是D

C语言的字符以其ASCII码的形式存在,所以要确定某个字符是大写字母,只要确定它的ASCII码在’A’和’Z’之间就可以了,选项B的书写格式错误,而选项C不符合要求。大写字母的ASCII码值的围为65到90,所以A 选项不符合要求,小写字母的ASCII码比大写字母的ASCII码大32,所以只有D是正确的。

28 答案是D

奇数和2求余一定不为0,所以当x为奇数时,x%2==0是不成立的,值为0,此题选择D。

29 答案是B

两个if语句的判断条件都不满足,程序只执行了c=a这条语句,所以变量c 的值等于3,变量b的值没有变化,程序输出的结果是3,5,3。所以本题选择B。

30 答案是C

表达式y%3==0的值为1,所以执行下面的输出语句,表达式—y的值为8,所以输出结果是8。选择C。

31 答案是C

表达式x%3的值为2,非0所以执行下面的输出语句,将x--的值8输出,此时x的值变为7,然后再执行下一个输出语句,将--x的值6输出,x的值也变为6,所以选择C。

32 答案是D

这是嵌套形式的switch语句,因为break结构影响较大,而此程序中的第一个case后没有break语句,程序执行时,x=1,执行嵌的switch语句,因y=0,执行a++,使变量a的值为1并终止层switch结构,回到外层。程序继续执行case 2后面的语句a++;b++;,这使变量a,b的值分别为2和1,外层switch语句结束。所以此题选择D。

33 答案是D

break与continue语句都可用于switch语句中。选择D。

二、填空题

1、答案是:10 20 0

分析:多数同学得到的答案是10 20 1,显然是没有弄清楚第三条赋值语句:c=(a%b<1)||(a/b>1).这是将后面一个逻辑表达式的值给c,那么关于逻辑表达式的考题,无非就是考察运算符的优先级,也就是说先算哪个,后算哪个的问题。在这个题里面,先计算第一个圆括号里面的容,a%b的值是10,所以10<1为假;a/b的值为0,0>1为假。在逻辑或运算的时候,两个运算对象都为假,则结果为假。所以c的值为0.答案是:10 20 0

2、答案是: 1

分析:程序中是一个if—else结构。这个题最容易出错的地方在于if的条件,注意,里面的是c=a是一个赋值表达式,不是将c与a的值进行比较。

所以条件为真,输出赋值以后c的值,为1。

3、答案是:4,5,99

分析:题中的重点在于两个if结构,大家要注意两点:第一,如果if后面没有花括号,则它后面的第一条语句是它的结构体,并且只有一条语句。(如果后面是一个结构,则整个结构都属于if结构的结构体)。第二,变量在不断的被重新赋值,所以其值在不断的变化。

4、答案是:yes

分析:该题与第二题是同一回事。

5、答案是:1

分析:这个题还上一个if—else结构,考查点仍然是考察考生是否能够正确识别if后面括号里的表达式p=a!=0,根据运算符的优先级知道,这里应该先算a!=0,这是一个逻辑运算,a的值为5,所以a!=0为真,其逻辑值为1,将1赋值给p,所以条件为真,输出p的值,为1。

6、答案是:20,0

分析:见第3题分析。

7、答案是:585858

分析:题中有三个if结构,注意,这三个if结构是相互独立的,是互不相关的,只要他们的条件成立,就要执行其结构体(后面的输出语句)。通过键盘输入,得a的值为58,所以a>50为真,输出58;然后判断a>40,仍然为真,再输出58,最后判断a>30,肯定为真,所以再输出58,连续三次输出58。

8、答案是:0

分析:本题的关键在于关系运算符的运算次序,a=5,b=4,c=3.a>b>c看起来是真的,但是这这是数学里面是这样的,这里我们要一步一步的计算,先算

a>b,a确实大于b,所以为真,逻辑值为1,后面的计算就变成了1>c,显然

为假,逻辑值为0,并将它赋值给d,所以最后输出d的值为0。

9、答案是:3

分析:这个题主要考察条件运算符。程序要输出(P/3>0?p/10:p%3)这个条件表达式的值。P为30,所以p/3=10,10>0显然为真,所以整个表达式的值应该是p/10的值,p/10得3。

10、答案是:2 1

分析:题中是一个switch嵌套结构。里面的switch是case 1的语句,题的关键点在于这个语句(即里面的这个switch结构)的后面并没有跳出整个结构的break语句。所以,当x=1,与case相配以后,执行完后面的语句(即里面的这个switch结构),然后没有遇到break语句,所以并不跳出结构体,而是继续执行case 2后面的语句。所以最后得到的结果应该是2 1,而不是1 0。

11、答案是:0

字符空格的ASCII码不为0,所以本题中表达式!c的值为0,b=0&&1的结果显然为0。

12、答案是:1

执行“j=!ch&&i++”时,首先判断j=!ch的值,因为ch=’$’不为0,所以j=!ch=0,编译便不再计算表达式i++的值,i的值不变仍为1。

13、答案是:-4

表达式!n的值为1,所以执行x-=1后x=1;表达式m的值为非0值,所以执行其后的语句x-=2后x的值为-1,表达式x的值也为非0,所以执行其后的语句后x的值为-4,最后输出x的值即为-4。

14、答案是:#&

表达式c==5的值为真,所以表达式的值等于1,因此输出符号“#”,然后执行“break”,继而去执行“default:printf(“&”);”语句,输出符号“&”。

15、答案是:1

因为在条件表达式(a

16、答案是:a:b c:t1

条件表达式类似于if语句,根据“?”前面子表达式的逻辑值来判断应该计算“:”前面的子表达式还是后面的作为整个条件表达式的结果。题目要求输出a、b、c3个变量中的最小值,所以当a

第四章循环结构

选择题:

1.答案:B

①N的值为10,n>7为真,执行循环体,n的值减1后为9,输出n的值9

②N的值为9,n>7为真,执行循环体,n的值减1后为8,输出n的值8

③N的值为8,n>7为真,执行循环体,n的值减1后为7,输出n的值7

④N的值为7,n>7为假,结束循环。

2.答案:A

k的值为5,进入循环,(--k)表达式的值为4(真),同时k的值改变为4,输出表达式k-=3的值1,同时k的值为1。k为1,表达式(—k)的值为0, 结束循环。

3.答案:A

1.X=0,y=5,z=3,(z>0&&x<4)值为真,进入循环体,y值为4,z值为2, x值为1

2.(z>0&&x<4)值为真,进入循环体, y值为3,z值为1, x值为2

3.(z>0&&x<4)值为真,进入循环体, y值为2,z值为0, x值为3

4.(z>0&&x<4)值为假,结束循环。

5.输出x,y,z的值3,2,0

4.答案:D

分析:

当K的值为3时,只执行case 3后面的语句n+=k,n的值为3;

当k的值为2时,先执行case 2后面的语句,但没有break,所以不会退出,继续执行case 3后面的语句n+=k,n的值为5;

当k的值为1时,先执行case 1后面的语句n+=k,n的值为6,先执行case 2后面的语句(没有),继续执行case 3后面的语句n+=k,n的值为7。输出n的值7。

5.答案:B

在循环体中有“s+=1;”s的初始值为0,要让s的值等于2必须是循环体执行两遍。当循环提执行两遍后a的值等于-3,所以在n=-3的时候循环体执行两遍后条件表达试(a!=0)为假,会退出循环。

6.答案:A

分析:

t值为1,s的值为0。从键盘中输入-3后,n的值为-3.先执行循环体。

执行s=s+t;s的值为1,执行t=t-2;t的值为-1.再判断表达式的值

t!=n为真,再次执行循环体。执行s=s+t;s的值为0,执行t=t-2;t的值为-3.再判断表达式的值

t!=n为假,结束do..while循环。最后输出s的值0。

7.答案:A

分析:x=3; 先执行循环体,输出表达式x-=2的值1,同时x的值也改变成

1,再判断表达式的值(!x),x的值为1(真),(!x)为假,循环结束。

8.答案:B

分析:B选项每次进入循环体,都要先执行p=1;即1赋值给p.所以不能求出5!的值

9.答案:D

分析:变量i每次增量为2,变化过程为:1->3->5->7->9,语句s+=1每次执行使s增加的数为:2,4,6,8,10,所以s的值为自然数1~10中偶数的值。

10.答案:C

分析:C项s=s+1/n, 1/n首先运算,n为整型变量,1也是整型变量,当n=2 (10)

时,1/n的值为整数0,故C不正确

11.答案:A

执行第一次循环时,a= 7,b = 4,a!=b为真继续循环。第二次循环a = 3,b=1,a!=b为真继续循环。第三次循环a = 2,b = 1, a!=b为真继续循环。第四次循环a = 1,b=1,

a!=b为假退出循环。

12.答案:C

13.答案:C

分析:x的值为15。执行while循环,(x>10)为真,执行循环体。执行x++;x 的值为16。再执行if语句。(x%3)为真,执行x++,x的值为17,再执行break;

语句,退出循环体,结束while语句的执行。最后输出x的值17。

14.答案:D

在循环中当x等于0,3,6,9时x%3等于0,这时会进入if语句执行printf 语句,在输出前x会先自加。屏幕上输出14710。

15.答案:D

分析:continue语句会提前结束此次循环体的执行,不会结束整个for语句的执行。

16.答案:2345

选择中没有此答案。

解析:本题注意的是在循环第一次进入switch语句的时候是执行的default 后面的语句块,由于没有break,所以还会执行case2:case4:后面的语句。

17.答案:A

本题答案为A

解析:A首先执行++n,判断条件表达式n<=0为假退出循环。B条件表达式1永远为真是无限循环,C条件表达式n的值为10永远为真是无限循环,D没有条件表达式,所以没有退出条件,是无限循环。此题要注意的是0为假,

历年二级C语言笔试真题及答案

1 2009年9月全国计算机等级考试二级笔试 试卷 1)下列数据结构中,属于非线性结构的是 A )循环队列 B) 带链队列 C) 二叉树 D )带链栈 2)下列数据结果中,能够按照“先进后出”原则存取数据的是 A) 循环队列 B) 栈 C)队列 D)二叉树 3)对于循环队列,下列叙述中正确的是 A )队头指针是固定不变的 B )队头指针一定大于队尾指针 C )队头指针一定小于队尾指针 D )队头指针可以大于队尾指针,也可以小于队尾指针 4)算法的空间复杂度是指 A )算法在执行过程中所需要的计算机存储空间 B )算法所处理的数据量 C )算法程序中的语句或指令条数 D )算法在执行过程中所需要的临时工作单元数 5)软件设计中划分模块的一个准则是 A) 低内聚低耦合 B) 高内聚低耦合 C) 低内聚高耦合 D) 高内聚高耦合 6)下列选项中不属于结构化程序设计原则的是 A) 可封装 B) 自顶向下 C) 模块化 D) 逐步求精 7)软件详细设计产生的图如下: 该图是 A) N-S 图 B) PAD 图 C) 程序流程图 D) E-R 图 8)数据库管理系统是 A )操作系统的一部分B) 在操作系统支持下的系统软件C) 一种编译系统 D) 一种操作系统 9)在E-R 图中,用来表示实体联系的图形是 A) 椭圆图B) 矩形C) 菱形D) 三角形 10)有三个关系R ,S 和T 如下: 其中关系T 由关系R 和S 通过某种操作得到,该操作为 A) 选择 B) 投影 C) 交 D) 并 11)以下叙述中正确的是 A )程序设计的任务就是编写程序代码并上机 B )程序设计的任务就是确定所用数据结 构 C )程序设计的任务就是确定所用算法 D )以上三种说法都不完整 12)以下选项中,能用作用户标识符的是 A )void B )8_8 C )_0_ D )unsigned 13)阅读以下程序 #include main() { int case; float printF; printf(“请输入2个数:”); scanf(“%d %f”,&case,&pjrintF); printf(“%d %f \n”,case,printF); } 该程序编译时产生错误,其出错原因是 A )定义语句出错,case 是关键字,不能 用作用户自定义标识符B )定义语句出错,printF 不能用作用户自定义标识符 C )定义语句无错,scanf 不能作为输入函 数使用 D )定义语句无错,printf 不能输出case 的值 14)表达式:(int)((double)9/2)-(9)%2的值是 A )0 B )3 C )4 D )5 15)若有定义语句:int x=10;,则表达式 x-=x+x 的值为 A )-20 B )-10 C )0 D )10 16)有以下程序 #include main() { int a=1,b=0; printf(“%d,”,b=a+b); printf(“%d \n”,a=2*b); } 程序运行后的输出结果是 A )0,0 B )1,0 C )3,2 D )1,2 17)设有定义:int a=1,b=2,c=3;,以下语 句中执行效果与其它三个不同的是 A )if(a>b) c=a,a=b,b=c; B )if(a>b) {c=a,a=b,b=c;} C ) if(a>b) c=a;a=b;b=c; D ) if(a>b) {c=a;a=b;b =c;} 18)有以下程序 #include main() { int c=0,k; for (k=1;k<3;k++) switch (k) {default: c+=k case 2: c++;break; case 4: c+=2;break; } printf(“%d \n”,c); } 程序运行后的输出结果是 A )3 B )5 C )7 D )9 19)以下程序段中,与语句:k=a>b?(b>c?1:0):0;功能相同的是 A )if((a>b)&&(b>c)) k=1;else k=0; B )if((a>b)||(b>c) k=1;else k=0; C )if(a<=b) k=0;else if(b<=c) k=1; D )if(a>b) k=1;else if(b>c) k=1; else k=0; 20)有以下程序 #include main() { char s[]={“012xy”};int i,n=0; for(i=0;s[i]!=0;i++) if(s[i]>=?a?&&s[i]<=?z?) n++; printf(“%d \n”,n); } 程序运行后的输出结果是 A )0 B )2 C )3 D )5 21)有以下程序 #include main() { int n=2,k=0; while(k++&&n++>2); printf(“%d %d \n”,k,n); } 程序运行后的输出结果是 A )0 2 B )1 3 C )5 7 D )1 2 22)有以下定义语句,编译时会出现编译错误的是 A )char a=?a? B )char a=?\n?; C )char a=?aa?; D )char a=?\x2d?; 23)有以下程序 #include main() { char c1,c2; c1=?A?+?8?-…4?; c2=?A?+?8?-…5?; printf(“%c,%d \n”,c1,c2); } 已知字母A 的ASCII 码为65,程序运行后的输出结果是

计算机二级c语言历年真题及答案

计算机二级c语言历年真题及答案【篇一:国家计算机二级c语言历年真题及答案】 class=txt>c语言程序设计 (考试时间90分钟,满分100分) 一、选择题((1)—(10)、(21)—(40)每题2分,(11)—(20)每题1分,共70分) (1)下列数据结构中,属于非线性结构的是 a)循环队列 b) 带链队列 c) 二叉树 d)带链栈 (2)下列数据结果中,能够按照“先进后出”原则存取数据的是 a) 循环队列 b) 栈 c)队列 d)二叉树 (3)对于循环队列,下列叙述中正确的是 a)队头指针是固定不变的 b)队头指针一定大于队尾指针 c)队头指针一定小于队尾指针 d)队头指针可以大于队尾指针,也可以小于队尾指针 (4)算法的空间复杂度是指 a)算法在执行过程中所需要的计算机存储空间 b)算法所处理的数据量 c)算法程序中的语句或指令条数 d)算法在执行过程中所需要的临时工作单元数 (5)软件设计中划分模块的一个准则是 a) 低内聚低耦合 b) 高内聚低耦合 c) 低内聚高耦合 d) 高内聚高耦合 (6)下列选项中不属于结构化程序设计原则的是 a) 可封装 d) 自顶向下

c) 模块化 d) 逐步求精 (7)软件详细设计产生的图如下: 该图是 a) n-s图 b) pad图 c) 程序流程图 d) e-r图 (8)数据库管理系统是 a)操作系统的一部分 b) 在操作系统支持下的系统软件 c) 一种编译系统 d) 一种操作系统 (9)在e-r图中,用来表示实体联系的图形是 a) 椭圆图 b) 矩形 c) 菱形 d) 三角形 (10)有三个关系r,s和t如下: 其中关系t由关系r和s通过某种操作得到,该操作为 a) 选择 b) 投影 c) 交 d) 并 (11)以下叙述中正确的是 a)程序设计的任务就是编写程序代码并上机调试 b)程序设计的任务就是确定所用数据结构 c)程序设计的任务就是确定所用算法 d)以上三种说法都不完整 (12)以下选项中,能用作用户标识符的是 a)void b)8_8 c)_0_ d)unsigned (13)阅读以下程序

全国计算机等级考试二级C语言真题

2009年3月二级C语言笔试真题((1)—(10)每小题2分,(11)—(50)每题1分,共60分) 下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的,请将正确选项涂写在答题卡相应位置上,答在试卷上不得分。 (1)下列叙述中正确的是 A)栈是“先进先出”的线性表 B)队列是“先进先出”的线性表 C)循环队列是非线性结构 D)有序性表既可以采用顺序存储结构,也可以采用链式存储结构 (2)支持子程序调用的数据结构是 A)栈B)树C)队列D)二叉树 (3)某二叉树有5个度为2的结点,则该二叉树中的叶子结点数是 A)10B)8C)6D)4 (4)下列排序方法中,最坏情况下比较次数最少的是 A)冒泡排序 B)简单选择排序 C)直接插入排序 D)堆排序 (5)软件按功能可以分为:应用软件、系统软件和支撑软件(或工具软件)。下面属于应用软件的是 A)编译软件 B)操作系统 C)教务管理系统 D)汇编程序 (6)下面叙述中错误的是 A)软件测试的目的是发现错误并改正错误 B)对被调试的程序进行“错误定位”是程序调试的必要步骤 C)程序调试通常也称为Debug D)软件测试应严格执行测试计划,排除测试的随意性 (7)耦合性和内聚性是对模块独立性度量的两个标准。下列叙述中正确的是 A)提高耦合性降低内聚性有利于提高模块的独立性 B)降低耦合性提高内聚性有利于提高模块的独立性

C)耦合性是指一个模块内部各个元素间彼此结合的紧密程度D)内聚性是指模块间互相连接的紧密程度 (8)数据库应用系统中的核心问题是 A)数据库设计 B)数据库系统设计 C)数据库维护 D)数据库管理员培训 (9)有两个关系R,S如下: 由关系R通过运算得到关系S,则所使用的运算为 A)选择B)投影C)插入D)连接 (10)将E-R图转换为关系模式时,实体和联系都可以表示为A)属性B)键C)关系D)域 (11)以下选项中合法的标识符是 A)1-1B)1—1C)-11D)1-- (12)若函数中有定义语句:intk;,则 A)系统将自动给k赋初值0 B)这时k中值无定义 C)系统将自动给k赋初值-1 D)这时k中无任何值 (13)以下选项中,能用作数据常量的是 A)o115B)0118C))115L (14)设有定义:intx=2;,以下表达式中,值不为6的是A)x*=x+1 B)x++,2*x C)x*=(1+x)

二级C语言试题(含答案)

二级C语言试题 一、判断题(2×8=16分) 1、printf()函数总是从新行的起始位置开始打印。( F ) 2、所有的变量在使用前都必须予以申明。(F) 3、在申明变量时必须给出变量的类型。(T) 4、C语言认为变量number和NuMbEr是相同的。( F) 5、打印三行输出的C语言程序必须用三条printf语句。(F) 6、求余运算符%只能用于两个整数操作数。(T) 7、switch选择结构中必须有default子句。(F) 8、如果x>y或ay&&a

全国计算机等级考试 历年真题2009年3月二级C语言笔试真题及答案

全国计算机等级考试历年真题2009年3月二级C语言笔试真题及答案 一、选择题(每题2分,共计70分) 1.(1)下列叙述中正确的是 A)栈是先进先出的线性表 B)队列是"先进后出"的线性表 C)循环队列是非线性结构 D)有序线性表即可以采用顺序存储结构,也可以采用链式存 储结构 A B C D 2.(2)支持子程序调用的数据结构是 A)栈 B)树 C)队列 D)二叉树 A B C D 3.(3)某二叉树有5个度为2的结点,则该二叉树中的叶子结点数是 A)10 B)8 C)6 D)4 A B C D 4.(4)下列排序方法中,最坏情况下比较次数最少的是 A)冒泡排序 B)简单选择排序 C)直接插入排序

D)堆排序 A B C D 5.(5)软件按功能可以分为:应用软件、系统软件和支撑软件(或工具软件)。下列 属于应用软件的是 A)编译程序 B)操作系统 C)教务管理系统 D)汇编程序 A B C D 6.(6)下面叙述中错误的是 A)软件测试的目的是发现错误并改正错误 B)对被调试程序进行"错误定位"是程序调试的必要步骤 C)程序调试也成为Debug D)软件测试应严格执行测试计划,排除测试的随意性 A B C D 7.(7)耦合性和内聚性是对模块独立性度量的两个标准。下列叙述中正确的是 A)提高耦合性降低内聚性有利于提高模块的独立性 B)降低耦合性提高内聚性有利于提高模块的独立性 C)耦合性是指一个模块内部各个元素间彼此结合的紧密程度 D)内聚性是指模块间互相连接的紧密程度 A B C D 8.(8)数据库应用系统中的核心问题是 A)数据库设计 B)数据库系统设计 C)数据库维护 D)数据库管理员培训

计算机二级C语言测试题及答案解析(一)

2016年计算机二级C语言测试题及答案解析(一)1.(A )是构成C语言程序的基本单位。 A、函数 B、过程 C、子程序 D、子例程 2.C语言程序从C 开始执行。 A、程序中第一条可执行语句 B、程序中第一个函数 C、程序中的main函数 D、包含文件中的第一个函数 3、以下说法中正确的是(C )。 A、C语言程序总是从第一个定义的函数开始执行 B、在C语言程序中,要调用的函数必须在main( )函数中定义 C、C语言程序总是从main( )函数开始执行 D、C语言程序中的main( )函数必须放在程序的开始部分 4.下列关于C语言的说法错误的是(B )。 A、C程序的工作过程是编辑、编译、连接、运行 B、C语言不区分大小写。 C、C程序的三种基本结构是顺序、选择、循环 D、C程序从main函数开始执行 5.下列正确的标识符是(C )。

B、a[i] C、a2_i D、int t 5~8题为相同类型题 考点:标识符的命名规则 只能由字母、数字、下划线构成 数字不能作为标识符的开头 关键字不能作为标识符 选项A中的“-”,选项B中“[”与“]”不满足(1);选项D中的int为关键字,不满足(3) 6.下列C语言用户标识符中合法的是(B )。 A、3ax B、x C、case D、-e2 E)union 选项A中的标识符以数字开头不满足(2);选项C,E均为为关键字,不满足(3);选项D中的“-”不满足(1); 7.下列四组选项中,正确的C语言标识符是(C )。 A、%x B、a+b C、a123

选项A中的“%”,选项B中“+”不满足(1);选项D中的标识符以数字开头不满足(2) 8、下列四组字符串中都可以用作C语言程序中的标识符的是(A)。 A、print _3d db8 aBc B、I\am one_half start$it 3pai C、str_1 Cpp pow while D、Pxq My->book line# His.age 选项B中的“\”,”$”,选项D中“>”,”#”,”.”,”-”不满足(1);选项C 中的while为关键字,不满足(3) 9.C语言中的简单数据类型包括(D )。 A、整型、实型、逻辑型 B、整型、实型、逻辑型、字符型 C、整型、字符型、逻辑型 D、整型、实型、字符型 10.在C语言程序中,表达式5%2的结果是C 。 A、2.5 B、2 C、1 D、3 %为求余运算符,该运算符只能对整型数据进行运算。且符号与被模数相同。5%2=1;5%

计算机二级c语言题库及答案

2016年计算机二级c语言题库及答案 一、选择题(每小题1分,共40小题,共40分) 1.设循环队列的存储空间为Q(1:35),初始状态为front=rear=35。现经过一系列入队与退队运算后,front=15,rear=15,则循环队列中的元素个数为( )。 或35 2.下列关于栈的叙述中,正确的是( )。 A.栈底元素一定是最后入栈的元素 B.栈操作遵循先进后出的原则 C.栈顶元素一定是最先入栈的元素 D.以上三种说法都不对 3.下列链表中,其逻辑结构属于非线性结构的是( )0、 A.双向链表 B.带链的栈 C.二叉链表 D.循环链表 4.在关系数据库中,用来表示实体间联系的是( )。 A.网状结构 B.树状结构 C.属性 D.二维表 5.公司中有多个部门和多名职员,每个职员只能属于一个部门,一个部门可以有多名职员。则实体部门和职员间的联系是( )。 :m联系 :n联系 :1联系 :l联系

6.右两个关系R和S如下: 则由关系R得到关系S的操作是( )。 A.自然连接 B.并 C.选择 D.投影 7.数据字典(DD)所定义的对象都包含于( )。 A.软件结构图 B.方框图 C.数据流图(DFD图) D.程序流程图 8.软件需求规格说明书的作用不包括( )。 A.软件设计的依据 B.软件可行性研究的依据 C.软件验收的依据 D.用户与开发人员对软件要做什么的共同理解 9.下面属于黑盒测试方法的是( )。 A.边界值分析 B.路径覆盖 C.语句覆盖 D.逻辑覆盖 10.下面不属于软件设计阶段任务的是( )。 A.制订软件确认测试计划 B.数据库设计 C.软件总体设计 D.算法设计 11.以下叙述中正确的是( )。 A.在C语言程序中,main函数必须放在其他函数的最前面 B.每个后缀为C的C语言源程序都可以单独进行编译 C.在C语言程序中,只有main函数才可单独进行编译

历年全国计算机二级C语言试题库完整

. . . . 参考 50道C 语言知识题 1.以下叙述中正确的是 A)用C 程序实现的算法必须要有输入和输出操作 B)用C 程序实现的算法可以没有输出但必须要有输入 C)用C 程序实现的算法可以没有输入但必须要有输出 D)用C 程序实现的算法可以既没有输入也没有输出 2.下列可用于C 语言用户标识符的一组是 A)void,define,WORDB)a3_3,_123,Car C)For,-abc,IFCaseD)2a,DO,sizeof 3.以下选项中可作为C 语言合法常量的是 A)-80B)-080C)-8e1.0D)-80.0e 4.若有语句:char*line[5];,以下叙述中正确的是 A)定义line 是一个数组,每个数组元素是一个基类型为char 为指针变量 B)定义line 是一个指针变量,该变量可以指向一个长度为5的字符型数组 C)定义line 是一个指针数组,语句中的*号称为间址运算符 D)定义line 是一个指向字符型函数的指针 5.以下定义语句中正确的是 A)inta=b=0;B)charA=65+1,b=′b′; 6.有以下程序段 charch;intk; ch=′a′; k=12; printf("%c,%d,",ch,ch,k);printf("k=%d\n",k); 已知字符a 的ASCII 码值为97,则执行上述程序段后输出结果是 A)因变量类型与格式描述符的类型不匹配输出无定值 B)输出项与格式描述符个数不符,输出为零值或不定值 C)a,97,12k=12 D)a,97,k=12 7.有以下程序 main() {inti,s=1; for(i=1;i<50;i++) if(!(i%5)&&!(i%3))s+=i; printf("%d\n",s);} 程序的输出结果是 A)409B)277C)1D)91 8.当变量c 的值不为2、4、6时,值也为"真"的表达式是 A)(c==2)||(c==4)||(c==6) B)(c>=2&&c<=6)||(c!=3)||(c!=5) C)(c>=2&&c<=6)&&!(c%2) D)(c>=2&&c<=6)&&(c%2!=1) 9.若变量已正确定义,有以下程序段

2009年3月二级C语言笔试真题及答案

2009年3月二级C语言笔试真题及答案 一、选择题(每题2分,共计70分) 1.(1)下列叙述中正确的是 A)栈是先进先出的线性表 B)队列是"先进后出"的线性表 C)循环队列是非线性结构 D)有序线性表即可以采用顺序存储结构,也可以采用链式存储结构 2. (2)支持子程序调用的数据结构是 A)栈 B)树 C)队列 D)二叉树 3. (3)某二叉树有5个读为2的结点,则该二叉树中的叶子结点数是 A)10 B)8 C)6 D)4 4. (4)下列排序方法中,最坏情况下比较次数最少的是 A)冒泡排序 B)简单选择排序 C)直接插入排序 D)堆排序 (5)软件按功能可以分为:应用软件、系统软件和支撑软件(或工具软件)。下列 属于应用软件的是 A)编译程序 B)操作系统 C)教务管理系统 D)汇编程序 (6)下面叙述中错误的是 A)软件测试的目的是发现错误并改正错误 B)对被调试程序进行"错误定位"是程序调试的必要步骤 C)程序调试也成为Debug D)软件测试应严格执行测试计划,排除测试的随意性 (7)耦合性和内聚性是对模块独立性度量的两个标准。下列叙述中正确的是 A)提高耦合性降低内聚性有利于提高模块的独立性 B)降低耦合性提高内聚性有利于提高模块的独立性 C)耦合性是指一个模块内部各个元素间彼此结合的紧密程度 D)内聚性是指模块间互相连接的紧密程度

(8)数据库应用系统中的核心问题是 A)数据库设计 B)数据库系统设计 C)数据库维护 D)数据库管理员培训 (9)有两个关系R,S如下: 由关系R通过运算得到关系S,则所使用的运算为 A)选择 B)投影 C)插入 D)连接 (10)将E-R图转换为关系模式时,实体和联系都可以表示为 A)属性 B)键 C)关系 D)域 (11)一下选项中合法的标识符是 A)1_1 B)1-1 C)_11 D)1_ _ (12)若函数中有定义语句:int k;,则 A)系统将自动给k赋初值0 B)这是k中的值无定义 C)系统将自动给k赋初值-1 D)这时k中无任何值 (13)一下选项中,能用作数据常量的是 A)o115 B)0118 C)1.5e1.5 D)115L (14)设有定义:int x=2;,一下表达式中,值不为6的是 A)x*=x+1 B)X++,2*x C)x*=(1+x) D)2*x,x+=2 15. (15)程序段:int x=12; double y=3.141593;printf("%d%8.6f",x,y);的输出结果是 A)123.141593 B)12 3.141593 C)12,3.141593 D)123.1415930

计算机二级C语言编程题库(100题)

2011,____年上机题100题库 1: 第1题m个人的成绩存放在score数组中,请编写函数fun,它的功能是:将低于平均分的人作为函数值返回,将低于平均分的分数放在below所指定的函数中。 答案: int fun(int score[],int m,int below[]) { int i,k=0,aver=0; for(i=0;i<m;i++) aver+=score[i]; aver/=m; for(i=0;i<m;i++) if(score[i]<aver) { below[k]=score[i]; k++; } return k; } 2: 第2题请编写函数fun,它的功能是:求出1到100之内能北7或者11整除,但不能同时北7和11整除的所有证书,并将他们放在a所指的数组中,通过n返回这些数的个数。

答案: void fun(int *a, int *n) { int i,j=0; for(i=2;i<1000;i++) if ((i%7==0 || i%11==0) && i%77!=0) a[j++]=i; *n=j; } 3: 第3题请编写函数void fun(int x,int pp[],int *n),它的功能是:求出能整除x且不是偶数的各整数,并按从小到大的顺序放在pp所指的数组中,这些除数的个数通过形参n返回。 答案: void fun(int x, int pp[ ], int *n) { int i=1,j=0;k=0,*t=pp; for(i=0;i<=x;i++) if(i%2!=0) { t[j]=I; j++; }

2020计算机二级C语言程序设计真题及答案(网友版)

2020计算机二级C语言程序设计真题及答案(网友版)【热点推荐】 | | | #include #include void proc(int num,int*b,int*c) { int i,j,d,y; for(i=3;i<=num/2;i=i+2) //****found**** { y=0; for(j=2;j<=sqrt((double)i);j++) if(i%j==0)y=0; if(y==l) //****found**** { d=i-num; for(j=2;j<=sqrt((double)d); j++) if(d%j==0)y=0; if(y==l) {*b=i;*c=d;) }

} } void main() { int mum,b,C; do { printf("\nlnput num:"); scanf("%d",&num);) while(num%2); ’ proc(num,&b,&c); printf("\n\n%d=%d+%d\n",num,b,c); } } 请编写函数proc(),其功能是:将str所指字符串中除下标为偶数,同时ASCII码值为奇数的字符外,其余的字符都删除,串中剩余字符所形成的一个新串放在t所指的数组中。例如,若str所指字符串中的内容为ABCDEFG12345,其中字符8的ASCII码值为偶数,所在元素的下标为奇数,所以必须删除;而字符A的ASCII码值为奇数,所在数组中的下标为偶数,所以不理应删除。依此类推,最后t所指的数组中的内容应是ACEG。 注意:部分源程序给出如下。 请勿改动main()函数和其他函数中的任何内容,仅在函数proc()的花括号中填入所写的若干语句。 试题程序: #include

2019二级C语言题库参考答案解析

2019年C语言考题答案 1、程序填空题 给定的程序的功能是调用fun函数建立班级通讯录。通讯录中记录 每位学生的编号、姓名和电话号码班级的人数和学生的信息从键盘 读入,每个人的信息作为一个数据块写到名为myfile5.dat的二进 制中。 填空:(1)STYPE (2)FILE (3)fp 改错:(1) for(i=0;i<=sl;i++) (2) t[2*sl]='\0'或t[sl+sl]='\0' 编程: *c=(a/10)*1000+(b/10)*100+(a%10)*10+(b% 10); 2、程序填空题 给定程序的功能是:从键盘输入若干文本(每行不超过80个字符),写到文件myfile4.txt中,用-1作为字符串输出输入的标志。然后将文件的内容读出显示在屏幕上。文件的读写分别由自定义函数ReadText 和Writetext实现。 填空:(1) *fw (2) str (3) str 改错:(1) void fun(long s,long *t)(2) s1=s1*10; 编程:int i,j=0,min=a[0].s; for(i=0;i

2009春江苏省计算机二级C语言试题与答案笔试

江苏省高校计算机等级考试2009年春季考试试题 第一部分计算机基础知识 1. 在下列有关现代信息技术的一些叙述中,正确的是 1 。 A.集成电路是20世纪90年代初出现的,它的出现直接导致了微型计算机的诞生 B.集成电路的集成度越来越高,目前集成度最高的已包含几百个电子元件 C.目前所有数字通信均不再需要使用调制解调技术和载波技术 D.光纤主要用于数字通信,它采用波分多路复用技术以增大信道容量‘. 2. 最大的10位无符号二进制整数转换成八进制数是 2 .。 A.1023 B.1777 C.1000 D.1024 3. 在下列有关目前PC机CPU的叙述中,错误的是 3 。 A.CPU芯片主要是由Intel公司和AMD公司提供的 B."双核"是指PC机主板上含有两个独立的CPU芯片 C.Pentium 4微处理器的指令系统由数百条指令组成 D.Pentium 4微处理器中包含一定容量的Cache存储器 4. 在下列有关当前PC机主板和内存的叙述中,正确的是 4 。 A.主板上的BIOS芯片是一种只读存储器,其内容不可在线改写 B.绝大多数主板上仅有一个内存插座,因此PC机只能安装一根内存条 C.内存条上的存储器芯片属于SRAM(静态随机存取存储器) D.目前内存的存取时间大多在几个到十几个ns(纳秒)之间 5. 在下列有关PC机辅助存储器的叙述中,正确的是 5 。 A.硬盘的内部传输速率远远大于外部传输速率 B.对于光盘刻录机来说,其刻录信息的速度一般小于读取信息的速度 C.使用USB 2.0接口的移动硬盘,其数据传输速率大约为每秒数百兆字节 D.CD-ROM的数据传输速率一般比USB 2.0还快 6. 在下列PC机I/O接口中,数据传输速率最快的是 6 。 https://www.360docs.net/doc/912390908.html,B 2.0 B.IEEE-1394 C.IrDA (红外) D.SATA 7. 计算机软件可以分为商品软件、共享软件和自由软件等类型。在下列相关叙述中,错误的是7 。 A.通常用户需要付费才能得到商品软件的使用权,但这类软件的升级总是免费的 B.共享软件通常是一种"买前免费试用"的具有版权的软件 C.自由软件的原则是用户可共享,并允许拷贝和自由传播 D.软件许可证是一种法律合同,它确定了用户对软件的使用权限 8. 人们通常将计算机软件划分为系统软件和应用软件。下列软件中,不属于应用软件类型的是8 A.AutoCAD B.MSN C.Oracle D.Windows Media Player 9. 在下列有关Windows 98/2000/XP操作系统的叙述中,错误的是9 。 A.系统采用并发多任务方式支持多个任务在计算机中同时执行 B.系统总是将一定的硬盘空间作为虚拟内存来使用 C.文件(夹)名的长度可达200多个字符 D.硬盘、光盘、优盘等均使用FAT文件系统 10. 在下列有关算法和数据结构的叙述中,错误的是10 。 A.算法通常是用于解决某一个特定问题,且算法必须有输入和输出 B.算法的表示可以有多种形式,流程图和伪代码都是常用的算法表示方法 C.常用的数据结构有集合结构、线性结构、树形结构和网状结构等 D.数组的存储结构是一种顺序结构 11?因特网的IP地址由三个部分构成,从左到右分别代表11 。 A.网络号、主机号和类型号 B.类型号、网络号和主机号 C.网络号、类型号和主机号 D.主机号、网络号和类型号 12?在下列有关ADSL技术及利用该技术接入因特网的叙述中,错误的是12 。 A.从理论上看,其上传速度与下载速度相同 B.一条电话线上可同时接听/拨打电话和进行数据传输

2017年全国计算机等级考试二级C语言真题及答案

2017年全国计算机等级考试二级笔试试卷 C 语言程序设计(附答案) (考试时间90 分钟,满分100 分) 一、选择题((1)—(10)、(21)—(40)每题2 分,(11)—(20)每题1 分,共70 分)下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的,请将正确的选项填涂在答题卡相应位置上,答在试卷上不得分。 (1)下列叙述中正确的是 A)线性表的链式存储结构与顺序存储结构所需要的存储空间是相同的 B)线性表的链式存储结构所需要的存储空间一般要多于顺序存储结构 C)线性表的链式存储结构所需要的存储空间一般要少于顺序存储结构 D)上述三种说法都不对 (2)下列叙述中正确的是 A)在栈中,栈中元素随栈底指针与栈顶指针的变化而动态变化B)在栈中,栈顶指针不变,栈中元素随栈底指针的变化而动态变化C)在栈中,栈底指针不变,栈中元素随栈顶指针的变化而动态变化D)上述三种说法都不对 (3)软件测试的目的是 A)评估软件可靠性 B)发现并改正程序中的错误 C)改正程序中的错误 D)发现程序中的错误 (4)下面描述中,不属于软件危机表现的是 A)软件过程不规范B)软件开发生产率低C)软件质量难以控制C)软件成本不断提高(5)软件生命周期是指 A)软件产品从提出、实现、使用维护到停止使用退役的过程 B)软件从需求分析、设计、实现到测试完成的过程 C)软件的开发过程 D)软件的运行维护过程 (6)面向对象方法中,继承是指 A)一组对象所具有的相似性质 B)一个对象具有另一个对象的性质 C)各对象之间的共同性质 D)类之间共享属性和操作的机制 (7)层次型、网状型和关系型数据库划分原则是 A)记录长度B)文件的大小B)联系的复杂程度D)数据之间的联系方式 (8)一个工作人员可以使用多台计算机,而一台计算机可被多个人使用,则实体工作人员与实体计算机之间的联系是 A)一对一B)一对多C)多对多D)多对一 (9)数据库设计中反映用户对数据要求的模式是 A)内模式B)概念模式C)外模式D)设计模式 (10)有三个关系R、S 和T 如下:

计算机二级C语言真题及答案

2014 年 3 月计算机二级 C 语言真题及答案 一、选择题 二、( 1)下列关于栈叙述正确的是 三、A) 栈顶元素最先能被删除 四、B)栈顶元素最后才能被删除 五、C) 栈底元素永远不能被删除? 六、D) 以上三种说法都不对 七、( 2)下列叙述中正确的是 八、A) 有一个以上根结点的数据结构不一定是非线性结构 九、B) 只有一个根结点的数据结构不一定是线性结构 十、C) 循环链表是非线性结构 十一、D)双向链表是非线性结构 十二、(3) 某二叉树共有7 个结点,其中叶子结点只有 1 个,则该二叉树的深度为(假设根结点在第 1 层) 十三、A)3? 十四、B)4? 十五、C)6? 十六、D)7 十七、(4) 在软件开发中,需求分析阶段产生的主要文档是 十八、A)软件集成测试计划? 十九、B)软件详细设计说明书二十、C)用户手册?

二十一、D)软件需求规格说明书 二十二、(5) 结构化程序所要求的基本结构不包括 二十三、A)顺序结构? 二十四、B)GOTC跳转 二十五、C)选择(分支)结构? 二十六、D)重复(循环)结构 二十七、(6) 下面描述中错误的是 二十八、A)系统总体结构图支持软件系统的详细设计 二十九、B)软件设计是将软件需求转换为软件表示的过程三十、C)数据结构与数据库设计是软件设计的任务之一 三十一、D)PAD图是软件详细设计的表示工具 三十二、(7) 负责数据库中查询操作的数据库语言是 三十三、A) 数据定义语言 三十四、B)数据管理语言 三十五、C)数据操纵语言 三十六、D)数据控制语言 三十七、 (8) 一个教师可讲授多门课程,一门课程可由多个教师讲授。则实体教师 和课程间的联系是 三十八、A)1:1 联系? 三十九、B)1:m 联系 四十、C)m:1 联系? 四十一、D)m:n 联系 四十二、(9)有三个关系R、S和T如下: 四十三、则由关系R和S得到关系T的操作是四十四、A) 自然连接?

计算机二级C语言测试题(含答案)

(第一章) 1. 以下关于算法的描述不正确的是__________。 A. 任何一个问题,它的实现算法是唯一的 B. 描述算法常用的表达工具有流程图、N-S图、PAD图、伪码等 C. 算法的最终实现是计算机程序 D. 正确性和清晰易懂性是一个好算法的基本条件 2.下面是一个加法程序,指出存在的逻辑错误和语法错误。 /* 求整数a和b的和*/ main( ) { int a,b; a=8; b=2000; print("%d\n",a-b); } 3.在每个C程序中都必须包含有这样一个函数,该函数的函数名为__________。A.main B. MAIN C. name D. function 4.以下叙述不正确的是__________。 A.C程序书写格式规定,一行内只能写一个语句 B.main()函数后面有一对花括号,花括号内的部分称为函数体 C.一个C程序必须有main()函数 D.C规定函数内的每个语句以分号结束 5.以下各标识符中,合法的用户标识符为_________。 A.A#C B.mystery C.main D.ab* 6.已知求解某问题的算法如下: ⑴输入a、b、c三个数。 ⑵将a和b比较,较大者放在a中,小者放在b中。 ⑶将a和c比较,较大者放在a中,小者放在c中。 ⑷将b和c比较,较大者放在b中,小者放在c中。 ⑸依次输出a、b、c。 请根据上述算法描述,把算法的功能表达出来。 【答案】把任意输入的三个数a、b、c按降序排列的顺序输出。 7.一个C语言程序可以包括多个函数,程序总是按照如下_________所描述的方式执行当前的程序。 A.从本程序的main()函数开始,到本程序文件的最后一个函数结束。 B.从本程序文件的第一个函数开始,到本程序文件的最后一个函数结束。 C.从main()函数开始,到main()函数结束。 D.从本程序文件的第一个函数开始,到本程序main()函数结束。 8.以下叙述正确的是_________。 A.在C程序中,main()函数必须位于程序的最前面。 B.C程序的每行中只能写一条语句。 C.在对一个C程序进行编译的过程中,可发现注释中的拼写错误。

计算机二级考试C语言试题及答案第一套

一、选择题(在下列各题的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,e2 B)e2,e4,e3,e1 C)e3,e4,e1,e2 D) 任意顺序 (8)将E-R图转换到关系模式时,实体与联系都可以表示成 A)属性 B)关系 C)键 D)域 (9)有三个关系R、S和T如下: R B C D a 0 k1 b 1 n1 S B C D f 3 h2 a 0 k1

(完整版)历年全国计算机二级C语言题库

50道C语言知识题 1.以下叙述中正确的是 A)用C程序实现的算法必须要有输入和输出操作 B)用C程序实现的算法可以没有输出但必须要有输入 C)用C程序实现的算法可以没有输入但必须要有输出 D)用C程序实现的算法可以既没有输入也没有输出 2.下列可用于C语言用户标识符的一组是 A)void,define,WORDB)a3_3,_123,Car C)For,-abc,IFCaseD)2a,DO,sizeof 3.以下选项中可作为C语言合法常量的是 A)-80B)-080C)-8e1.0D)-80.0e 4.若有语句:char*line[5];,以下叙述中正确的是 A)定义line是一个数组,每个数组元素是一个基类型为char为指针变量 B)定义line是一个指针变量,该变量可以指向一个长度为5的字符型数组 C)定义line是一个指针数组,语句中的*号称为间址运算符 D)定义line是一个指向字符型函数的指针 5.以下定义语句中正确的是 A)inta=b=0;B)charA=65+1,b=′b′; C)floata=1,*b=&a,*c=&b;D)doublea=00;b=1.1; 6.有以下程序段 charch;intk; ch=′a′; k=12; printf("%c,%d,",ch,ch,k);printf("k=%d\n",k); 已知字符a的ASCII码值为97,则执行上述程序段后输出结果是 A)因变量类型与格式描述符的类型不匹配输出无定值 B)输出项与格式描述符个数不符,输出为零值或不定值 C)a,97,12k=12 D)a,97,k=12 7.有以下程序 main() {inti,s=1; for(i=1;i<50;i++) if(!(i%5)&&!(i%3))s+=i; printf("%d\n",s);} 程序的输出结果是 A)409B)277C)1D)91 8.当变量c的值不为2、4、6时,值也为"真"的表达式是 A)(c==2)||(c==4)||(c==6) B)(c>=2&&c<=6)||(c!=3)||(c!=5) C)(c>=2&&c<=6)&&!(c%2) D)(c>=2&&c<=6)&&(c%2!=1) 9.若变量已正确定义,有以下程序段 inta=3,b=5,c=7;

相关文档
最新文档