求二进制最右为1的位是第几位
来源:互联网 发布:手机淘宝5星好评在哪看 编辑:程序博客网 时间:2024/05/01 03:22
这段代码来自https://github.com/erlang/otp/blob/master/erts/emulator/sys/common/erl_mseg.c
static const int debruijn[32] = {0, 1, 28, 2, 29, 14, 24, 3, 30, 22, 20, 15, 25, 17, 4, 8,31, 27, 13, 23, 21, 19, 16, 7, 26, 12, 18, 6, 11, 5, 10, 9};#define LOW1BIT(X) (debruijn[((unsigned int)(((X) & -(X)) * 0x077CB531U)) >> 27])
分析:
首先计算(x) & (-x),根据反码计算规则-x就是x按位取反结果再加1,假设为1的最低位是第k位,则-x中的第31~(k+1)位与x中的31~(k+1)位每一位都是相反的,-x和x中的(k-1)~0位都是0,而两个的第k位都是1,因此x和-x做与运算会得到2^k。
此程序比较巧妙的位置是乘和右移,我猜作者的本意是想找到一个映射关系,使得集合A中的元素x=2^i(其中i=0,1,...31),与集合B中的元素(0,1,...31)形成双射关系,能满足这个条件的映射会有很多种,而此程序中找到的映射关系应该是其中比较简洁的一种。0x077CB531U没有什么特别之处,通过下面的程序可以找到4096个能替代它的值,但是可能需要修改debruijn数组。
#include <stdio.h>int main(){unsigned int k = 1 ,t = 1 ,s;int i;unsigned int bitmap[32];unsigned int pow2[32];memset(bitmap ,0 ,sizeof(bitmap));for(i = 0 ;i < 32 ;i ++)pow2[i] = 1<<i;while(k != 0xFFFFFFFF) {for(i = 31 ; i >= 0 ;i --) {s = (pow2[i] * k) >> 27;if(bitmap[s] < t) {bitmap[s] = t;} else {break;}}if(i < 0) {printf("0x%XU\n" ,k);//break;}++ k;++ t;}return 0;}
- 求二进制最右为1的位是第几位
- 求N!的二进制表示最低位的1的位置(从右向左数)
- 返回指定的 int 值的二进制补码表示形式中最低(“最右”)的为 1 的位后面的零位个数
- HDOJ11632进制第几位是1
- 求32位int二进制下最左边的bit '1'
- 快速求一个32位无符号整数二进制中为1的个数
- 快速求一个32位无符号整数二进制中为1的个数
- 求32位无符号整数中比特为1的二进制位数
- Python求一个数对应二进制最低位为1对应的数字lowbit
- 计算一个整数二进制表示时有多少位是为1的算法
- 求二进制包含的1的个数(位操作)
- 求n的阶层二进制最低位1的位置
- 求32位整数二进制1的个数
- 求32位整数二进制中1的个数
- 求一个32位二进制数中的1的个数
- 位操作一 求二进制中1的个数
- 位操作_求二进制中1的个数
- 求N!二进制最低位1的位置
- VBS清除全盘网页文件被挂马代码【VBS专杀】
- css和html中的dom节点都是怎么被处理的
- android开发 Activity的里面调用两次 setContentView方法
- Linux 共享库: LD_LIBRARY_PATH 与ld.so.conf
- ESB企业服务总线
- 求二进制最右为1的位是第几位
- EAI和SOA比较
- wxPython实现截图功能(二)
- Git 命令参数及用法详解
- 迷宫之解。
- Java基础复习:Properties类
- HDU 4561 金山居 连续最大积
- 机房收费系统完美设计——事务处理vs三层架构2
- 基于python的c++ 类空实现代码生成器