基本算法_位运算_lowbit

lowbit运算

lowbit(n)定义为非负整数n在二进制表示下“最低位的1及后面的所有0”构成的数值。比如二进制10011111010的lowbit就是最后两位10。

那么我们如何得到lowbit的值呢?

首先:取反。

 ~ 10011111010

 = 01100000101

然后:+1

   01100000101+1

= 01100000110

我们会发现,此时只有lowbit与原二进制相同,此时再与原数字相与即可得到lowbit(n)

综上可得lowbit的运算公式

  lowbit(n) = n & ( ~ n + 1 ) 

又在补码中,~n+1= - n,所以

  lowbit(n) = n & (- n)

那lowbit有什么应用呢?我们可以求得一个数字二进制中所有1的个数,从而得到0的个数……

只需要不断把n的值赋为n-lowbit( n )即可~

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值