您的位置:首页 > 其它

简洁判断一个byte中有多少位为1的bit?

2013-08-06 16:10 113 查看
以下是Brian W. Kernighan公开的一个方法
unsigned bit_count(unsigned v)
{
unsigned int c; //置位总数累计

for (c = 0; v; c++)
{
v &= v - 1; //去掉最低的置位
}

return c;
}

// 15的二进制为1111, 调用后为1的bit数为 4
unsigned bitNum = bit_count(15);

以上方法在VC6.0 + Win7下通过验证。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐