编程之美--BYTE二进制数中1的个数

22 篇文章 0 订阅

书中提到五种解法,我也没想到其他方法了。

1.除以2

int Count(BYTE v)
{ 
      int num = 0;
      while(v)
     {
         if(v % 2 == 1)
           {
                 num++;
            }
          v = v / 2;
      }
   return num;
}

2. 位操作

int Count(BYTE v)
{ 
      int num = 0;
      while(v)
     {
          num += v & 0x01;   
            v >>= 1;
 }  
      return num;
 }

3.减一操作
int Count(BYTE v)
{ 
      int num = 0;
      while(v)
     {
        v &= (v - 1);
        num++;
      }
   return num;
}

4.分支。5.查表法。这两种相对来说比较固定,没有灵活性,在此不列举了。
扩展问题:
1.如果变量是32位的DWORD,你会使用上述的哪一个算法,或者改进哪一个算法?

个人认为是第三个,时间复杂度是O(M),M为v中1的个数。



















评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值