题目:输入一个整数,输出该数二进制表示中1的个数。其中负数用补码表示。
class Solution {
public:
int NumberOf1(int n) {
int count = 0;
while(n){
count ++;
n = n & (n - 1);
}
return count;
}
};
这里使用了一个小技巧,即如果n的二进制数中至少含有一个1,n&(n-1)的运算结果会把数字n的二进制数的最右面的1变为0,因而一直运算到n等于0时的运算次数即为数字n的二进制表示中1的个数。