关于 x &= (x – 1) -c 言语学习笔记之一

x &= (x – 1)可以删除x中最右边值为1 的一个二进制位

x-1,其实就是把x最右端的1变为0,1左边的其余位不变。 

如: x=7 

// x= 111  

//x-1 后 x = 110  

// x & x-1 = 110, --- 第一次  

// x再次减一,即x-1 后 x =101  

// x & x-1 = 100 ----第二次  

// x-1 后 x= 011  

// x & x-1 = 000 ----第三次


如上,三个即把三个二进制的1消去。

利用此特性,即可统计其整型参数的值为1的二进制位的个数。

方法如下:

int bitcount(unsigned x)
{
int b;
for (b = 0; x != 0; x &= (x - 1))
b++;
return b;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值