二进制中1的个数

题目:

计算在一个 32 位的整数的二进制表式中有多少个 1.

解法一:
static int count;//1的个数
public int countOnes(int num) {
// write your code here
while( num != 0 ){
if( (num & 1) == 1)
count++;
num = num>>1;//将num右移一位
}
return count;
}
解法一的缺陷就是:必须要循环32次才能得出1的个数,所以时间复杂度比较高。

解法二: 从二进制的角度讲,n相当于在n - 1的最低位加上1
static int count;//1的个数
public int countOnes(int num) {
for(count = 0 ; num != 0 ; count++ ){
num = num & (num -1);
}
return count;
}

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容