您的位置:首页 > 其它

位运算之求整数二进制的最低位1的权值

2015-07-27 20:53 399 查看
两种方法:1、 n-(n&(n-1))

n&(n-1)是消去二进制数中的最低位1

2、 n&(-n)

注意:int n;此时的n为带符号的整数

lowbit(i):将i转化成二进制数之后,只保留最低位的1及其后面的0,截断前面的内容,然后再转成10进制数

X^:X取反(符号我这里定的,不是什么官方符号)

lowbit(x)实际上是提取x从左往右数的最后一个1。

设x为a1b,a1b中的1位最后一个1,a和b都表示一串01串(当然b全为0或者不存在),如13=1101则a=110,b不存在。

对一个数x取负相当于该数的二进制取反再加1,所以-x = (a^1^ b^) = (a^ 0 1...1) +1 = (a^ 1 0...0)。

则 x & (-x) = (a 1 00...) & (a^ 1 00...) = (0...0 1 0...0)。结果就是保留最后个1和后面的0的十进制答案。


内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: