第一题
1. 执行c程序代码,a,b,c,d的值分别为()
int a = 1; int b = 0; int c = 0; int d = (++a) * (c = 1);
A:2,0,1,2
B:1,0,1,1
C:2,0,1,1
D:2,0,0,2
答案及解析 A
本题考查的重点在d变量定义这里
d = ( ++a ) * (c = 1)
前置++表达式的值为++之后的值,所以++a = 2;此时a = 2
c = 1 这种赋值表达式的值是恒为真的,所以赋值表达式的结果为1;此时 c = 1
所以 d = 2 * 1 = 2;
a = 2;b = 0;c = 1;d = 2;
第二题
2. 以下程序运行后的输出结果是()
#include <stdio.h> #define S(x) 4*x*x+1 int main() { int i=6,j=8; printf("%d\n",S(i+j)); return 0; }
A:21
B:41
C:61
D:81
答案及解析 D
本题考查的是#define宏替换
所以S(i + j) = 4 * i + j * i + j + 1 = 4 * 6 + 8 * 6 + 8 + 1 = 81
第三题
3. 下面代码在32位计算机中输出的结果是()
struct TEST_TYPE { int a; int b; }; int testSize(struct TEST_TYPE val[10]) { return sizeof(val); }
A:4
B:8
C:10
D:80
答案及解析 A
本题考查的是求变量所占的空间大小,所以直接看val,val是结构体数组的数组名,但是这里的结构体数组是形参,数组作为形参的时候,类型是指针类型
相当于struct TEST_TYPE *val,所以val是指针类型,指针类型在32位大小为4字节。
第四题
4. 若有以下程序段,不能正确引用字符串的选项是( )
char str[4][12] = {"aa", "bbb", "cccc", "d"}; char *strp[4]; for (int i = 0; i < 4; i++) { strp[i] = str[i]; }
A:str[0]
B:strp
C:strp[3]
D:* strp
答案及解析 B
这里我们要知道,二维数组名是代表的第一行的地址,二维数组的行是代表的每一行的首元素地址,所以为了可以引用字符串,一定是要拿到二维数组行;正因如此,strp这个指针数组的每个元素都是二维数组str的行
A:str[0],二维数组的行,是第一行的首元素的地址,字符串只要知道首元素地址就可以引用
B:strp,这是指针数组的数组名,是数组首元素的地址,也就是 &strp[0],而strp数组,是存放指针的,也就是存地址的,那对地址取地址,就是另外一个地址了,因为我们不能保证strp[0]的地址,是跟字符串的首元素地址有关系的,而且这时候strp是一个二级指针,所以无法引用字符串;
C:strp[3],这个就是str[3],可以拿到字符串;
D:*strp,这个是对的,strp是strp[0]的地址,解引用后就是strp[0],而strp[0]存的是str[0],是二维数组第一行的首元素的地址,aa,可以正确引用字符串;
第五题
5. 若已有定义:int a = 2, b = 3, c = 4; 则表达式 !(a + b) - c + 1 || c + b / 2 的值是( )
A:-2
B:-1
C:0
D:1
答案及解析 D
!(a + b) - c + 1 || c + b / 2
= !5 - 4 + 1 || c + b / 2
= 0 - 4 + 1 || c + b / 2
= -3 || c + b / 2
= 1
这里记住||,是从左往右计算的,有1就是1,而0是0,非0就是1;左边为1,就是真,右边不会计算了。所以结果为1;