题目描述
输入一个整数,输出该数二进制表示中1的个数。其中负数用补码表示。
思路
负数用补码,其实就是求一个数据在计算机中是存储是怎么样子的。用位运算,就能很好实现。
class Solution {
public:
int NumberOf1(int n) {
int count = 0;
int flag = 1;
while (flag != 0) {
if ((n & flag) != 0) {
count++;
}
flag = flag << 1;
}
return count;
}
};
一般用左移,左移为逻辑左移。移到最后,便为0了。