【C语言】练习题整理:12

前言

今天记录的是10道选择题

1

题目

下列程序的输出是( )

#include
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 结果是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

前面的运算很容易想到,要注意的是:
&&运算前表达式为假,则后面的括号(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

解答

因为两个地址相加无意义,并且也可能越界,所以规定不允许指针相加

结语

今天的十道选择题到这里就结束了,希望对你有帮助,我们下次见~

你可能感兴趣的:(C语言错题集,c语言,开发语言)