前言
今天记录的是10道选择题
1
题目
下列程序的输出是( )
#include<stdio.h> int main() { int a [12]= {1,2,3,4,5,6,7,8,9,10,11,12},*p[4],i; for(i=0;i<4;i++) p[i]=&a [i*3]; printf("%d\n",p[3][2]); return 0; }
答案
12
解答
p是一个指针数组,元素个数是4
p[i] = &a[i*3]相当于是把数组a每3个一组分开并把每组的首地址存在p数组,
此时p类似一个4行3列的二维数组,p[3][2]就是4行第3个元素12
2
题目
二维数组X按行顺序存储,其中每个元素占1个存储单元。若 X[4][4] 的存储地址为 Oxf8b82140 , X[9][9] 的存储地址为 Oxf8b8221c ,则 X[7][7] 的存储地址为( )
A: Oxf8b821c4 B: Oxf8b821a6 C: Oxf8b82198 D: Oxf8b821c0
答案
解答
这就是一道数学题。
假设每行有n个元素:
那x[9][9]元素的地址 - x[4][4]元素的地址
= 0x21c-0x140=5n+5(21c和140是地址末三位的十六进制数),
这里n是43,
假设x[7][7]的地址是z,x[7][7]元素的地址 - x[4][4]元素的地址
= z-0x140 = 3n+3,z =3n+3+140 =3*43+3+0x140 =0x84+0x140=0x1c4,看地址的尾数,选择A
3
题目
以下哪个选项可以正确描述 sizeof(double) ( )
A: 一个整型表达式 B: 一个双精度型表达式 C: 一个不合法的表达式 D: 一种函数调用
答案
A
解答
首先sizeof是操作符,不是函数,直接排除D,这点已经强调过很多遍了
此处可能有人想选B,觉得因为有double所以觉得是双精度浮点型,
但,在此处要强调的是:sizeof它的返回值是字节数,是无符号整型
所以是整型表达式
4
题目
求函数返回值,传入 -1 ,则在64位机器上函数返回( )
int func(int x) { int count = 0; while (x) { count++; x = x&(x - 1);//与运算 } r eturn count; }
A: 死循环 B: 64 C: 32 D: 16
答案
C
解答
x=x&(x-1)这个表达式执行一次就会将x的2进制中最右边的1去掉,在x变成0之前,表达式能执行几次,就去掉几个1,
所以这个代码实现了求一个有符号整数二进制补码中1的个数的功能,我们知道-1的补码是全1,而int类型4个字节32位,所以选C
5
题目
若有 int w=1, x=2, y=3, z=4; 则条件表达 w < x ? w : y < z ? y : z 的值是( )
A: 1 B: 2 C: 3 D: 4
答案
A
解答
这道题可以理解成:
w < x ? w : (y < z ? y : z )
w<x,所以结果就是w
结果是1
6
题目
下面代码的运行结果是:
int main() { int a=1,b=2,m=0,n=0,k; k=(n=b<a)&&(m=a); printf("%d,%d\n",k,m); return 0; }
答案
0 0
解答
k=(n=b<a)&&(m=a);这部分的执行顺序如下:先执行n=b<a部分,其中,关系运算符优先级高于赋值运算符,所以先算b<a,得到0,n=0赋值运算的结果将作为括号内表达式的结果,即(n=b<a)&&(m=a)转换成(0)&&(m=a),0与上任意数都是0,所以k是0
前面的运算很容易想到,要注意的是:
&&运算前表达式为假,则后面的括号(m=a)不再运算,m值还是0,所以m=0
7
题目
下面代码的输出结果是:
void func() { int k = 1^(1 << 31 >> 31); printf("%d\n", k); }
答案
-2
解答
运算顺序:先计算1 << 31 ,再计算>> 31,最后与1异或
(1 << 31 );左移31位,并在右侧填充0,得到0x80000000,即符号位为1,其他为0,即-2147483648
int k = 1^(1 << 31 >> 31);注意,这里在右移的时候,符号位保持为1,右移后填充1,结果为0xFFFFFFFF,即-1,
0x00000001^0xFFFFFFFF,即0xFFFFFFFE(-2)
8
题目
假设编译器规定 int 和 short 类型长度分别为32位和16位,若有下列C语言语句,则 y 的机器数为( )
unsigned short x = 65530; unsigned int y = x;
答案
0000 FFFA
解答
unsigned short类型的x变量2个字节保存了65530,十六进制形式为0xFFFA,x给y赋值时会整型提升,而无符号数在提升时高位补0,其实就相当于把x的值放在了y的低2个字节的空间中,所以是 0000 FFFA
9
题目
要使 a 的低四位翻转,需要进行操作是( )
A: a|0xF B: a&0xF C: a^0xF D: ~a
答案
C
解答
十六进制数0xF是4位1,参与运算时整型提升,高位都是0。低四位和1异或,01是1,11是0;高位和0异或,00是0,10是1。故而可以通过异或F使得a的低四位翻转,并保持高位不变
10
题目
以下选项中,对基本类型相同的两个指针变量不能进行运算的运算符是( )
A: + B: - C: = D: ==
答案
A
解答
因为两个地址相加无意义,并且也可能越界,所以规定不允许指针相加
结语
今天的十道选择题到这里就结束了,希望对你有帮助,我们下次见~