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

两种方法: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的十进制答案。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值