C语言面试每日一题:位运算符的运用

Posted 南风过境蜻蜓飞

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C语言面试每日一题:位运算符的运用相关的知识,希望对你有一定的参考价值。

记录、总结C语言经典面试题,备忘

1. 题目

计算一个字节里有多少位被置1

2. 示例代码

/* 公众号:南风过境蜻蜓飞 */

#include "stdio.h"
#define BIT (0x1<<7)

int get_num(unsigned char );

int get_num(unsigned char x)
{
int i;
int count = 0;
unsigned char comp = BIT;

for(i = 0; i <sizeof(x) * 8; i++)
{
if((x & comp) != 0)
{
count++;
}
comp = comp >>1;
}
return count;
}

int main(void)
{
unsigned char a = 0;
int num = 0;

printf("请输入一个字节:");
scanf("%d",&a);
num = get_num(a);
printf("输入的一个字节里有%d位被置1\r\n",num);

return 0;
}

3. 代码分析、验证

题目主要考察位运算符的运用。解题方法:将一个字节里的8位分别判断是否被置为1

一个字节(byte)有8位,计算一个字节里有多少位被置1,首先在宏定义中将最高位置1,然后循环比较每个位是否被置成1,若是,则count++,循环结束返回返回count的值

测试:在VS Code 里编写以上代码,编译运行,输入值66(二进制:1000010),按照理论,代码运行结束后,返回的count值应该为2

测试如下,输入66,返回的count值为2,与理论值吻合

C语言面试每日一题:位运算符的运用(1)

4. 扩展

上面的代码我们是将宏定义最高位置1,然后循环比较每一位,对原代码做简单改动,将宏定义最低位置1,然后循环比较每一位,也可达到一样的效果,代码如下:

/* 公众号:南风过境蜻蜓飞 */

#include "stdio.h"
#define BIT (0x80>>7)

int get_num(unsigned char );

int get_num(unsigned char x)
{
int i;
int count = 0;
unsigned char comp = BIT;

for(i = 0; i <sizeof(x) * 8; i++)
{
if((x & comp) != 0)
{
count++;
}
comp = comp << 1;
}
return count;
}

int main(void)
{
unsigned char a = 0;
int num = 0;

printf("请输入一个字节:");
scanf("%d",&a);
num = get_num(a);
printf("输入的%d有%d位被置1\r\n", a, num);

return 0;
}

测试如下,输入66,返回的count值为2,与理论值吻合C语言面试每日一题:位运算符的运用(1)

内容来自《C和C++程序员面试秘笈》,笔者知识有限,如果发现本文有错误的地方欢迎批评、指正,若本文对您有所帮助,转发、分享也是笔者坚持的动力

好文分享:


以上是关于C语言面试每日一题:位运算符的运用的主要内容,如果未能解决你的问题,请参考以下文章

每日一题位运算交换两数

笔试强训每日一题

leetcode每日一题(2020-4-28):面试题56 - I. 数组中数字出现的次数

算法·每日一题(详解+多解)-- day15

算法·每日一题(详解+多解)-- day15

算法·每日一题(详解+多解)-- day15