计算机二级《C语言》考前巩固练习题2016
1.C语言中,关系表达式和逻辑表达式的值是 B 。
A、0
B、 0或1
C、 1
D、‘T’或’F’
2. 下面 D 表达式的值为4.
A、 11/3
B、 11.0/3
C、 float11/3
D、 int11.0/3+0.5
【解析】1相同数据类型的元素进行数学运算+、-、*、/得到结果还保持原数据类型。
2不同数据类型的元素进行数学运算,先要统一数据类型,统一的标准是低精度类型转换为高精度的数据类型。
选项A,11与3为两个整数,11/3结果的数据类型也应为整数,因此将3.666666的小数部分全部舍掉,仅保留整数,因此11/3=3.
选项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
3.设整型变量 a=2,则执行下列语句后,浮点型变量b的值不为0.5的是 B
A、b=1.0/a
B、b=float1/A、
C、b=1/floata
D、b=1/a*1.0
4. 若“int n; float f=13.8;”,则执行“n=intf%3”后,n的值是A
A、1
B、4
C、4.333333
D、4.6
【解析】“intf“表示将f中的值强制类型转换为整型,即将13.8的小数部分舍掉,转换为13;然后计算13%3,结果为1,再将结果赋给变量n,因此n的值为1
5. 以下对一维数组a的正确说明是: D
A、char a10;
B、 int a[];
C、int k=5,a[k];
D、char a[3]=‘a’,’b’,’c’;
【解析】详见教材P143~144,一维数组的定义、初始化
类型符 数组名 [常量表达式]
类型符是指数组中数组元素的`类型;数组名要符合标识符命名规则;常量表达式是指数组的长度数组中包含元素的个数,其值只能是整数,不可以是变量,而且从1开始计数。
选项A,常量表达式只能放在中括号 [ ]中
选项B,只有在对数组初始化即赋值的时候才可以省略数组的长度,B中并未对a进行初始化。
选项C,常量表达式不能为变量。
6.以下能对一维数组a进行初始化的语句是: C
A、int a[5]=0,1,2,3,4,
B、 inta5=
C、 int a[3]=0,1,2
D、 int a5=10*1
【解析】详见教材P145,一维数组的定义、初始化
选项B,D,常量表达式只能放在中括号 [ ]中
选项A,数组可以看做是若干个相同数据类型元素的有序集合,因此以集合的形式对其初始化,使用 对其初始化,选项A用了.
7.在C语言中对一维整型数组的正确定义为 D 。
A、int a10;
B、int n=10,a[n];
C、int n;a[n];
D、#define N 10
8、已知:int a[10]; 则对a数组元素的正确引用是 D 。
A、a[10]
B、a[3.5]
C、a5
D、a[0]
【解析】详见教材P144,数组元素的引用
数组名[下标]
引用数组元素时,[ ]中的下标为逻辑地址下标,只能为整数,可以为变量,且从0开始计数
int a[10]表示定义了一个包含10个整型数据的数组a,数组元素的逻辑地址下标范围为0~9,即a[0] 表示组中第1个元素; a[1] 表示组中第2个元素; a[2] 表示组中第3个元素; ......;a[9] 表示组中第10个元素.
选项A,超过了数组a的逻辑地址下标范围;
选项B,逻辑地址下标只能为整数
选项C,逻辑地址下标只能放在[ ]中
9.若有以下数组说明,则i=10;a[a[i]]元素数值是C 。
int a[12]=1,4,7,10,2,5,8,11,3,6,9,12;
A、10
B、9
C、6
D、5
【解析】先算a[a[i]]内层的a[i],由于i=10,因此a[i]即a[10].
a[10]对应下面数组中的元素为9. 因此a[a[i]]即为a[9]
a[9]对应下面数组中的元素为6. 因此a[9]即为6
10.若有说明:int a[][3]=1,2,3,4,5,6,7; 则数组a的第一维的大小为: B
A、2
B、3
C、4
D、无确定值
【解析】二维数组的一维大小,即指二维数组的行数,在本题中,按行对二维数组赋值,因此内层有几个大括号,数组就有几行