博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
《剑指offer》-统计整数二进制表示中1的个数
阅读量:5037 次
发布时间:2019-06-12

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

题目描述

输入一个整数,输出该数二进制表示中1的个数。其中负数用补码表示。

直观思路就是把二进制表示从右往左统计1的个数。直接想到移位操作来迭代处理。坑点在于负数的移位操作会填充1。有人贴出了逻辑移位操作,但还是麻烦。直接按照int的位数,32或64,做这么多次移位操作就好了,每次移位操作累计是否为1。int的位数是32还是64,可以写一个函数来做到,而不是硬编码。

class Solution {public:    int  NumberOf1(int n) {        int cnt = 0;        int i = 0;        int int_bit_length = get_int_bit_length();        while (i
> 1); i = i + 1; } return cnt; } int get_int_bit_length(){ int a = 1; int bit_cnt = 0; while (a != 0){ a = (a<<1); bit_cnt += 1; } return bit_cnt; }};

转载于:https://www.cnblogs.com/zjutzz/p/6501564.html

你可能感兴趣的文章
npm安装cnpm、vue、react
查看>>
通过adb命令打印log
查看>>
error rabbitMQ:Error: unable to perform an operation on node 'rabbit@xxxx'.
查看>>
js倒计时
查看>>
JSON数据检测是否正确
查看>>
hbase部署经验与坑总结
查看>>
腾讯QQ内测群新功能:QQ万人群即将袭来!
查看>>
iOS 事件处理机制与图像渲染过程
查看>>
数字是否可以被3和5同时整除,use if and % (21.9.2017)
查看>>
Warsaw University Contest Petrozavodsk, Thursday, January 31, 2008 F题,Gym100096F
查看>>
lcx端口转发 linux版
查看>>
arcgis server 10.1 发布动态图层展示海量及频繁更新的数据步骤
查看>>
strncat_s
查看>>
避免复制引用程序集的XML文件
查看>>
C IO(一般性)
查看>>
机器学习中的贝叶斯方法---先验概率、似然函数、后验概率的理解及如何使用贝叶斯进行模型预测(2)...
查看>>
SQL Server 2005 数据库 可疑状态
查看>>
L1-Day4
查看>>
搭建mocha测试环境并使用selenium进行测试
查看>>
Javascript测试之karma + mocha
查看>>