当前位置: 首页 > news >正文

统计二进制中比特1的个数

快速统计比特1的数量

int CountBitOnes(int32_t n) {int result = 0;for(;n;++result) {n &= n-1;}return result;
}
原理很简单,n-1会将n中最靠近结尾的1减一,这样n&n-1,n中最靠近结尾的1就变成了0;
假设n = 0b xxxxxxxx100
n - 1 = 0b xxxxxxxx011
n&n-1= 0b xxxxxxxx000

这样从后往前,依次将1置为0同时result+1,最终n为0时,得出result表示共有多少个1。

正数和负数的区别

众所周知,计算机存储数据是以补码的方式,那么正数的补码和原码相同可以得到正确的比特数,如:

n = 10
二进制表示:00000000000000000000000000001010
计算得到result = 2

负数由于是补码,计算得到的只能是补码的比特数,如:

n = -10
原码表示:10000000000000000000000000001010
补码表示:11111111111111111111111111110110
由于计算机存储补码,计算result = 30

结论:

  • 通过这种方式计算非常快,最差时间复杂度为o(n),且仅有减法和与操作这种简单的操作。

  • 正数可以得到正确的比特1的数量,负数得到的是补码的比特1的数量。

http://www.lryc.cn/news/12750.html

相关文章:

  • 第三方实现跑马灯和手写实现跑马灯
  • React Native Cannot run program “node“问题
  • python基于vue微信小程序 房屋租赁出租系统
  • ThreadPoolExecutor管理异步线程笔记
  • MotoSimEG-VRC教程:动态输送带创建以及示教编程与仿真运行
  • PyTorch 并行训练 DistributedDataParallel完整代码示例
  • Golang实现ttl机制保存内存数据
  • js中数字运算结果与预期不一致的问题和解决方案
  • C++ Primer Plus 学习笔记(一)——基本类型
  • ChatGpt与Google 谁能给出最好的回答
  • 【Redis】一、CentOS64 安装 Redis
  • Redis底层原理(持久化+分布式锁)
  • Spring Cloud Nacos实战(八) - Nacos集群配置
  • 什么是低代码-甲骨文对低代码的定义
  • shell编程之循环语句
  • 神经动力学-第一章-神经动力学基础-神经系统的元素
  • 【力扣-LeetCode】64. 最小路径和 C++题解
  • Mysql数据库事务
  • 【opencv源码解析0.3】调试opencv源码的两种方式
  • Xcode Archives打包上传 / 导出ipa 发布至TestFlight
  • RNN GRU模型 LSTM模型图解笔记
  • 西电_数字信号处理二_学习笔记
  • [ vulhub漏洞复现篇 ] Drupal 远程代码执行漏洞(CVE-2018-7602)
  • MySQL最佳实践
  • Python 之 Matplotlib 散点图、箱线图和词云图
  • SpringCloud(三)Hystrix断路器服务降级、服务熔断、服务监控案例详解
  • 【超好用】自定义的mybatis-plus代码生成器
  • Kubernetes学习笔记-计算资源管理(4)监控pod的资源使用量20230219
  • 游戏开发 - 开发流程 - 收集
  • LA@向量空间@坐标变换