位运算小妙招-求二进制序列中1的个数

简介: 位运算小妙招-求二进制序列中1的个数

题目要求

🥩输入一个正整数N,求二进制序列补码中所含1的个数

解法1

🍲 类似于得到十进制数的每一位

image.png

🥫相同的道理,如果我们想知道二进制序列有多少个1,只需要让正整数N不断%2进行判断,使用计数器,统计1的个数,当N为0时,跳出循环

image.png

🍇代码如下

size_t count_bit_one(int n)
{
    size_t count = 0;
    while(n)
    {
        if(n%2 == 1)
        {
            count++;
        }
        n = n/2;
    }
    return count;
}
复制代码

🍤改进: 当我们输入的是负数时,结果会出错,因为整数在内存中以补码形式存储,所以我们可以把参数定义为无符号整数(size_t  即unsigned int) ,这样传参为负数时也不会出错

size_t count_bit_one(size_t n)
{
    size_t count = 0;
    while(n)
    {
        if(n%2 == 1)
        {
           count++;
        }
        n = n/2;
    }
    return count;
}
复制代码

解法2

🥂想办法得到二进制序列中的每一位,这样就要使用到位运算的知识了。

🥨按位与运算& :    0&1 = 0 1&1 = 1    所以我们可以让二进制序列的每一位和1进行与运算,如果对于的二进制序列的位为1,那么结果就是1,反之则是0.


🍷那么我们怎么得到二进制序列中的每一位呢?这里就需要用到右移的知识点了.

右移得到每一位的二进制比特位之后,与1相与进行判断。使用计数器进行计数,如果相与的结果为1,计数器+1

🍮右移:移动的是比特位.


image.png

🍼代码如下

size_t count_bit_one(int n)
{
    int i = 0;
    size_t count = 0;
    for (i = 0; i < 32; i++)
    {
        //n不断右移,对应的二进制位和1相与进行判断,共进行32次
        if (((n >> i) & 1) == 1)
        {
            count++;
        }
    }
    return count;
}
int main()
{
    int n = 0;
    scanf("%d", &n);
    size_t count = count_bit_one(n);
    printf("%d的二进制序列的1的个数为:%u\n", n,count);
  return 0;
}
复制代码

解法3

🍪此处我们要知道n&(n-1)代表什么含义

🥈n&(n-1) :去掉二进制序列中最低位的1  

👢只要知道进行了多少次n&(n-1)运算就知道二进制序列有多少个1


image.png


⚽代码如下

size_t count_bit_one(int n)
{
    size_t count = 0;
    while(n)
    {
        n = n&(n-1);
        count++;
    }
    return count;
}
复制代码

总结

🥼x|(x+1)   : 把二进制序列中最低位的0变成1  可以用此方法统计二进制序列中0的个数,每使用一次,就把低位的0变成1,最后为全1序列、只要统计通过几次使用,值变成-1,就知道二进制序列有多少个0

👕当二进制序列全为1时(补码):代表的值为:-1

👔n&(n-1) : 去掉二进制序列中最低位的比特位1 可以用此方法统计二进制序列中1的个数,每使用一次,就把低位的1变成0,最后为全0序列,只要统计通过几次使用,值变成0,就知道二进制序列有多少个1


相关文章
|
7月前
|
算法 Java
算法编程(十四):颠倒二进制位
算法编程(十四):颠倒二进制位
59 0
|
2月前
|
Java 开发者
【编程基础知识】2的n次幂与二进制位全为1之间的联系,为啥只差一个1
本文深入探讨了2的n次幂与二进制位全为1之间的数学联系,解释了2的n次幂减一的二进制表示为何全为1,并探讨了这一特性在HashMap中的应用。通过基础数学原理和实际代码示例,文章揭示了这一特性的实用价值,适合各水平的编程爱好者学习。
26 3
|
算法 Python
算法|仙游二进制,探访位运算
算法|仙游二进制,探访位运算
53 0
|
机器学习/深度学习 C++
剑指offer 14. 二进制中1的个数
剑指offer 14. 二进制中1的个数
62 0
|
算法 C语言
编程之美求二进制数中1的个数
编程之美求二进制数中1的个数
97 0
|
C语言
下面【整型提升】的例题,你会几道?学完这一课,你将真正拿捏整型提升问题
下面【整型提升】的例题,你会几道?学完这一课,你将真正拿捏整型提升问题
149 0
下面【整型提升】的例题,你会几道?学完这一课,你将真正拿捏整型提升问题
【刷穿 LeetCode】371. 两整数之和 : 使用「位运算」求解的两种方式
【刷穿 LeetCode】371. 两整数之和 : 使用「位运算」求解的两种方式
|
机器学习/深度学习 算法 前端开发
「LeetCode」剑指Offer15二进制中1的个数⚡️
「LeetCode」剑指Offer15二进制中1的个数⚡️
99 0
「LeetCode」剑指Offer15二进制中1的个数⚡️
|
存储
位运算小妙招-求二进制序列中0的个数
位运算小妙招-求二进制序列中0的个数
917 0
位运算小妙招-求二进制序列中0的个数
|
算法 Java 编译器
每日一练(8):二进制中1的个数
编写一个函数,输入是一个无符号整数(以二进制串的形式),返回其二进制表达式中数字位数为 '1' 的个数(也被称为 汉明重量).)。
124 0