博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[bit]整数二进制表示中1的个数
阅读量:7184 次
发布时间:2019-06-29

本文共 434 字,大约阅读时间需要 1 分钟。

hot3.png

摘自《深入理解计算机系统》(中文版,第二版)的习题3.49,64位系统,算法如下:

long fun_c(unsigned long x ) {  long val = 0;  int i;  for ( i = 0; i < 8; i++ ) {    val += x & 0x0101010101010101L; // 注意:这里是0x表示的    x >>= 1;  }  val += (val >> 32);  val += (val >> 16);  val += (val >> 8);    return val & 0xFF;}
上面这个算法是把1个64位整数的8个字节分别算二进制表示时1的个数(因为1个字节有8个二进制位,所以循环8次),之后将所有的8个表示位数的值相加即可。

BTW: 如果是计算1的个数奇偶性的话,可以直接使用PF标志位。

转载于:https://my.oschina.net/luckykiddie/blog/100275

你可能感兴趣的文章
命令-df/du
查看>>
整合 Tachyon 运行 Apache Flink(译)
查看>>
写给走在IT路上的我。。
查看>>
新手初识webservice-理论篇
查看>>
成功者的共同特点
查看>>
iOS中的多线程
查看>>
Oracle客户端配置说明 centos
查看>>
鸟哥学习笔记---NIS
查看>>
spring framework最新发布压缩包的下载问题
查看>>
hadoop-1.2.1集群安装
查看>>
c++类中的const
查看>>
markdown使用*
查看>>
13年下半年信息系统项目管理师考试总结
查看>>
为什么受伤的总是技术大牛
查看>>
我的友情链接
查看>>
Composer 笔记(PHPconf 台湾)
查看>>
linux双网卡绑定
查看>>
Python 三元运算符与lambda
查看>>
ethtool 的使用方法
查看>>
用NGUI动态添加和删除Sprite
查看>>