9,求整数的二进制中1的个数《剑指offer》

时间:2021-02-10 21:00:19

题目:

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

思路:

通过 1 的左移来和这个整数的每一位进行与操作,计算出二进制中1的个数

代码:

class Solution {
public:
int NumberOf1(int n) {
int count=0;
int flag=1;
while(flag){
if(n&flag) count++;
flag = flag << 1;
}

return count;
}
};