如何找数的第一个bit为1的位置

一:查表法:

该方法一般在掩码长度为8位时比较常见,即定义一个数组X,数组长度为2 的n次方,n为掩码的长度。如掩码为8位时可定义一个256个单元的数组,数组第m个单元初始化为但掩码值为m时其第一个为1位的位置,比如m= 0xF4,则11110100b,其第一个为一的位在bit2上,则X[m]=2,同理但X[0xF5]=0,当然X[0x00]=-1。有了这张表,那么查找比特1位置的函数实现很简单:

int X[256]={-1,0,1,0,...}
int GetUnUseMem(U8 UseMask)
{
    return X[UseMask];
}
对于32位的:可以分级查找。

int GetUnUseMem(U32 UseMask)
{
    int    Ret;
    if((Ret= X[UseMask&0xFF])>=0) goto GetUnUseMem_End;
    if((Ret= (X[UseMask&0xFF00 >>8] +8))>=0) goto GetUnUseMem_End;
    if((Ret= (X[UseMask&0xFF0000 >>16] +16))>=0) goto GetUnUseMem_End;
    Ret= X[UseMask&0xFF000000 >>24] +24;
GetUnUseMem_End:
    return Ret;
}

二:直接位运算:

int proc(unsigned int n){
   unsigned int index=n;
  index=(index-1)&~index;
    index=index&0x55555555+((index>>1)&0x55555555);
    index = index&0x33333333+ ((index>>2)&0x33333333);
    index = index&0x0F0F0F0F+ ((index>>4)&0x0F0F0F0F);
    index = index&0xFF + (index&0xFF00 >> 8) + (index&0xFF0000 >> 16) + (index&0xFF000000 >> 24);
    return (int)(index);
}
int main(void)
{
    cout<<proc(4)<<endl;
    return 0;
}

试了一下好像不行。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值