经原国家教育委员会(现教育部)批准、由教育部考试中心主办、面向社会、用于考查非计算机专业应试人员计算机应用知识与技能的全国性计算机水平考试体系,是全国计算机等级考试(National Computer Rank Examination,以下简称 NCRE)。下面是 2017 年计算机二级 C 语言测试题及答案解析。欢迎阅读。

2017年计算机二级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 )。

A、-a1

B、a

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

D、123

选项A里的“%” ,选项B之中的“+”不符合(1) ,选项D内的标识符以数字起始不符合(2)。

8、下列四组由字符组成的串里,全都能够被用作C语言程序里的标识符号的是( A)。

A、print _3d db8 aBc

B、Iam one_half start$it 3pai

C、str_1 Cpp pow while

D、Pxq My->book line#

选项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的结果等于2。

11.如果int a=3,b=4;则条件表达式"aA、 3

B、 4

C、 0

D、1

详见教材P97.

表达式1?表达式2:表达式3

先计算表达式1,

要是表达式1得以成立,那么就去选择计算表达式2,并且把表达式2的值当作整个大表达式的值。

倘若表达式1是不成立的情形,那么就要去选择计算表达式3,并且要把表达式3所具有的值当作整个大表达式的值。

该题目里的aa是3,b是4。a12.要是int x等于2,y等于3,z等于4 那么表达式x ,句末标点符号。

A、4

B、3

C、2

D、0

E)1

13.C语言中,关系表达式和逻辑表达式的值是( B ) 。

A、0

B、 0或1

C、 1

D、‘T’或’F’

14. 下面( D )表达式的值为4.

A、 11/3

B、 11.0/3

C、 (float)11/3

D、 (int)(11.0/3+0.5)

14~16题为同一类型

详见教材P54~56.

(1)对具有相同数据类型的元素,实施数学运算,也就是像加运算、减运算、乘运算或者除运算这样的操作之后,所获取到的结果仍旧维持原本的数据类型。

(2)不是直接对具有不同数据类型的元素去开展数学运算,而是得首要进行数据类型的统一,统一所依据的标准是将低精度类型转变为高精度的数据类型。

选择项A,十一与三是两个整数,十一除以三所得结果的数据类型同样应当是整数,所以把三点六六六六六六的小数部分全部舍弃掉,仅仅留存整数,故而十一除以三等于三。

选项B那里,11.0属于实数范畴,3是整数,所以首先得统一数据类型,把整型的3转成3.0才行,在转换之后数据类型会统一成实型数据,那会儿选项B就变成11.0/3.0 ,结果的数据类型同样应该是实型数据,故而选项B 11.0/3等于3.666666。

选项C,首先把整数11进行强制类型转换,转变成实型11.0,于是选项C就变成了11.0/3,在这之后的计算过程,并且结果与选项B是相同的。

选项D,先是计算11.0除以3,其计算的过程以及结果跟选项B是一样的,所得到的结果是3.666666,接着计算3.666666加上0.5,得出结果为4.166666,最后把4.166666进行强制类型转换成为整型,也就是把它的小数部分全部舍弃掉,最终结果是4。

15.设定一个整型类型的变量a,其值为2,那么在执行下面这些语句之后,对于浮点型变量b而言,其值并非0.5的情况是( B )。

A、b=1.0/a

B、b=(float)(1/A、

C、b=1/(float)a

D、b=1/(a*1.0)

16. 要是存在“int n; float f=13.8;”这种情况,那么在执行“n=(int)f%3”之后,n所具有的值是(A)。

A、1

B、4

C、4.333333

D、4.6

“(int)f”意味着把f当中的值强行进行类型变换,使之成为整型,也就是把13.8的小数部分舍弃掉,转变为13,接着计算13%3,其结果是1,而后把该结果赋予变量n,所以n的值是1。

17. 以下对一维数组a的正确说明是: D

A、char a(10);

B、 int a

C、int k=5,a

D、char a

={‘a’,’b’,’c’};

详见教材P143~144,一维数组的定义、初始化

类型符 数组名

常量表达式

数组元素的类型所指的是类型符,数组名需契合标识符命名规则,数组的长度,也就是常量表 达式,指的是数组中含有的元素个数,其值必须是整数,且不能是变量,并且是从1开始计数的。

选项A,常量表达式只能放在中括号

选项B,唯有在针对数组开展初始化(也就是赋值)这个行为的时候,才能够省略数组的长度,B情形里并没有对a实施初始化。

选项C,常量表达式不能为变量。

18.以下能对一维数组a进行初始化的语句是:( C )

A、int a

=(0,1,2,3,4,)

B、 inta(5)={}

C、 int a

={0,1,2}

D、 int a{5}={10*1}

详见教材P145,一维数组的定义、初始化

选项B,D,常量表达式只能放在中括号

选项A,数组能够被视作是由若干个具有相同数据类型的元素所构建成的有序集合,所以依照集合的形式来对它进行初始化,采用{ }来为其实施初始化举动,然而选项A却运用了()。

19.在C语言中对一维整型数组的正确定义为 D 。

A、int a(10);

B、int n=10,a

C、int n;a

D、#define N 10

int a

20、已知:int a

10

; 则对a数组元素的正确引用是( D )。

A、a

10

B、a

3.5

C、a(5)

D、a

详见教材P144,数组元素的引用

数组名

下标

引用数组元素时,

中之下标,乃是逻辑地址下标,仅能为整数,能够为变量,并且是从0开始计数。

int a

10

用于表明定义出了一个存有10个整型数据内容的数组a,该数组元素所具备的逻辑地址下标涵盖范围是从0至9,也就是a。

表示组中第1个元素; a

表示组中第2个元素; a

表示组中第3个元素; ......;a

表示组中第10个元素.

选项A,超过了数组a的逻辑地址下标范围;

Logo

有“AI”的1024 = 2048,欢迎大家加入2048 AI社区

更多推荐