位操作符、移位操作符的应用(剑指 15 二进制中1的个数)

位操作符

&  按位与:遇00
|  按位或:遇11
^  按位异或:相同为0,相异为1
注:都是在二进制的情况下,且操作数都是整数

移位操作符

<<  左移操作符
>>  右移操作符
注:都是在二进制的情况下
左移操作符

左移:左边抛弃,右边补0
在这里插入图片描述

在这里插入图片描述

num << 1,左移之后的值发生了变化,但是此时左移之后的值并没有赋值给num,所以num只剩的值并没有改变。

int num = 9;
num = num << 1;

此时num的值就发生了改变

右移操作符
逻辑移位

左边用0填充,右边丢弃
在这里插入图片描述

算术移位

右边丢弃,左边用改值原来的符号位填充
在这里插入图片描述
注意:对于移位操作数,不要移动负数位,如:

int num = -1;
num << -1;  //  出错

标准为定义,所以避免这样使用

计算二进制中1 的个数

请实现一个函数,输入一个整数,输出该数二进制表示中 1 的个数。例如,把 9 表示成二进制是 1001,有 2 位是 1。因此,如果输入 9,则该函数输出 2。

采用移位操作符和位操作符:

class Solution {
public:
    int hammingWeight(uint32_t n) {
        uint32_t count = 0;
        while(n)
        {
            if((n&1)==1)//和1与操作,取出二进制的最后一位
            {
                count++;
            }
                n>>=1;//右移丢弃
        }
        return count;
    }
};

总结
要牢记这两种操作符的特性,位操作符和移位操作符在某些场合还是很方便的,灵活性很高,效率也比较高,这个具体的问题具体讨论。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值