C语言--每日五道选择题--Day4

第一题

1、如果 x=2014 ,下面函数的返回值是( )

cpp 复制代码
int fun(unsigned int x)
{
    int n = 0;
    while(x + 1)
    {
        n++;
        x = x | (x + 1);
    }
    return n;
}

A: 20

B: 21

C: 23

D: 25

答案及解析 C

这个函数的作用是对整型中0的个数进行统计

**x = x | (x+1)**的作用是每次循环把x的二进制中从右往左数的最后一位0变成1,直道变成全1的时候x+1就溢出为全0,循环结束。

2014的二进制是0000 0000 000 0000 0000 0111 1101 1110,一共有9个1,所以就有23个0,需要循环23次,才能溢出,n就等于23,所以结果是23

第二题

2、下列语句定义 x 为指向 int 类型变量 a 的指针,其中哪一个是正确的( )
A: int a , *x = a;

B: int a , *x = &a;

C: int *x = &a , a;

D: int a , x = a;

答案及解析 B

A选项的x是指针,赋值时使用a不合适

C选项在赋值时a变量还没定义

D选项中的x不是指针

第三题

3、下面有关空指针和未初始化指针,说法错误的是( )
A: 对0x0这个地址取值是非法的

B: 空指针可以确保不指向任何对象或函数; 而未初始化指针则可能指向任何地方

C: 空指针与任何对象或函数的指针值都不相等

D: malloc在其内存分配失败时返回的是一个未初始化的指针

答案及解析 D

malloc函数在内存分配失败时返回NULL,其余选项都正确

第四题 (做错了)

4、若有定义 int a[8]; ,则以下表达式中不能代表数组元素 a[1] 的地址的是( )
A: &a[0]+1

B: &a[1]

C: &a[0]++

D: a+1

答案及解析 C

C:a[0]先和++结合,形成一个表达式,不能对表达式取地址,会报错

D:a计算时是首元素地址,再加1,就是a[1]的地址。因为a是指向int类型的,a+1会向后移4个字节,所以指向a[1]的位置。

第五题

5、以下选项中,对基本类型相同的两个指针变量不能进行运算的运算符是( )
A: +

B: -

C: =

D: ==

答案及解析 A

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

B选项,可以求出两个数据元素储存位置之间的相隔同数据类型的元素个数

C选项,赋值,没问题

D选项,判断两指针是否相同

相关推荐
2401_838472516 小时前
C++中的访问者模式
开发语言·c++·算法
老鼠只爱大米6 小时前
LeetCode经典算法面试题 #108:将有序数组转换为二叉搜索树(递归分治、迭代法等多种实现方案详解)
算法·leetcode·二叉树·二叉搜索树·平衡树·分治法
csbysj20206 小时前
《Foundation 开关:深度解析其原理与应用》
开发语言
独自破碎E7 小时前
【前缀和+哈希】LCR_011_连续数组
算法·哈希算法
梦里小白龙7 小时前
java 通过Minio上传文件
java·开发语言
一条大祥脚7 小时前
26.1.26 扫描线+数论|因子反演+子序列计数|树套树优化最短路
数据结构·算法
m0_561359677 小时前
基于C++的机器学习库开发
开发语言·c++·算法
星空露珠7 小时前
速算24点所有题库公式
开发语言·数据库·算法·游戏·lua
2401_832402757 小时前
C++中的类型擦除技术
开发语言·c++·算法
努力学习的小廉7 小时前
我爱学算法之—— 递归回溯综合(二)
开发语言·算法