题目描述
输入一个整数,输出该数二进制表示中1的个数。其中负数用补码表示。
思路:一个数二进制,好比 ,1100,把这个数减去1, 1011 ,然后把这两个数做与运算, 为1000 ,此时还剩一个1 。然后再减去1 为 0111 ,然后把1000和0111做与运算 ,此时结果为0000..这种解法复杂度相对较低。
public class Solution {
public int NumberOf1(int n) {
int num = 0;
while (n != 0) {
n = n & (n - 1);
num++;
}
return num;
}
}