计算二进制中1的个数

如何计算一个整数中二进制中1的个数

int fu�nc(int x)
{
  int count = 0;
  while(x)
  {
    count ++;
    x = x&(x-1);
  }
  return 0;
}

理解这个算法的核心是:

  • 当一个数被减1时,它最右边的那个值为1的bit将变为0;同时其右边的所有的bit都会变成1。
  • 每次执行x&(x-1)的作用是把x对应的二进制数中的最后一位1去掉。因此,循环执行这个操作直到x等于0的时候,循环的次数就是x对应的二进制中1的个数。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • ERROR ITMS-90535: "Unexpected CFBundleExecutable Key. The...
    架构师的一小步阅读 4,084评论 0 0
  • 夜雨道美景独惜,寂寞情愁悠我心。 叹别离焉非知己,恍若尤隔千万里。 ——— ...
    君照阅读 1,118评论 0 0
  • ——读大冰的系列作品有感 -虫二 经人推荐,我去看了《乖,摸摸头》,便一发不可收拾,一口气看完了大冰作为一个野生作...
    365读书计划阅读 2,812评论 0 2