位运算之求整数二进制的最低位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的十进制答案。
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的十进制答案。
相关文章推荐
- 用数组实现链表的好处
- [置顶] 程序员练级指南
- iOS陀螺仪计算行走的步数
- hdoj 4183 Pahom on Water 【网络流 简单题】【dinic求最大流】
- Vector
- SignalR实现服务器与客户端的实时通信
- [转]MySQL创建用户与授权方法
- 修改PD的OOM生成脚本
- 不使用第三个变量,交换两个变量的值
- UVA 573 The Snail
- CCMenu的布局
- Permutation Sequence
- [转]MySQL与Oracle的语法区别详细对比
- 基于递归的二叉树遍历
- C++引用
- C++面试宝典(整理版)6
- HDU 1452 Happy 2004(唯一分解定理)
- 采药问题
- UIScrollViewDelegate的回调方法解析
- 【峰回路转】Excel技巧百例 06.设置下拉框