题目描述
输入一个整数,输出该数二进制表示中1的个数。其中负数用补码表示。
答题框架
class Solution {
public:
int NumberOf1(int n) {
}
};
解题分析
因为负数给的是补码 所以不用手动转换
直接利用和2的整指数被进行位运算&就可以
代码
class Solution {
public:
int NumberOf1(int n) {
int count=0;
unsigned int flag=1;
while(flag){
if (n & flag){
count++;
}
flag=flag<<1;
}
return count;
}
};