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

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

前言

今天记录的是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

解答

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

结语

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


相关文章
|
6月前
|
C语言
C语言练习题解析(2)
C语言练习题解析(2)
56 0
|
6月前
|
存储 C语言
C语言练习题解析(1)
C语言练习题解析(1)
60 0
|
C语言
【C语言】练习题整理:11
【C语言】练习题整理:11
133 1
|
C语言 CDN
C语言基础练习题(2)
C语言基础练习题(2)
128 1
|
C语言
C语言基础练习题(1)
C语言基础练习题(1)
70 0
|
人工智能 算法 测试技术
【C语言】初阶完结练习题
C语言初阶知识点已经全部更完,相信大家对C语言初阶已经有了一个整体的概念,但我们只知道一些理论上的知识还是没有用的,所以今天我在网上找了一些题目给大家练习巩固之前学的知识,这样能更好的帮助我们加深对其的理解。
226 0
|
1月前
|
C语言
C语言练习题代码
C语言练习题代码
|
3月前
|
机器学习/深度学习 存储 C语言
【C语言篇】C语言常考及易错题整理DAY1
swap函数调用时用的是全局变量,主函数中定义的变量只在主函数中有效,因为主函数也是一个函数,它与其他函数是平 行关系;输出语句这里,考虑局部优先的原则。
165 1
|
3月前
|
C语言
【C语言篇】C语言常考及易错题整理DAY3
基本数据类型的等级从低到高如下:char int long float double运算的时候是从低转到高的,表达式的类型会自动提升或者转换为参与表达式求值的最上级类型。
20 0
|
3月前
|
存储 人工智能 大数据
【C语言篇】C语言常考及易错题整理DAY2
p是一个指针数组,p[i] = &a[i*3]相当于是把数组a每3个一组分开并把每组的首地址存在p数组,此时p类似一个4行3列的二 维数组,p[3][2]就是4行第3个元素12。
53 0