输入一个整数 n ,输出该数32位二进制表示中1的个数。其中负数用补码表示。 
   数据范围: 
  
   即范围为: 
  
 10
2
十进制中10的32位二进制表示为0000 0000 0000 0000 0000 0000 0000 1010,其中有两个1。
-1
32
负数使用补码表示 ,-1的32位二进制表示为1111 1111 1111 1111 1111 1111 1111 1111,其中32个1
public class Solution {
    public int NumberOf1(int n) {
        int ans=0;
        while(n!=0){
            ans+=n&1;//判断n的最右位是不是1
            n>>>=1;  //把n向右移动一位
        }
        return ans;
    }
}
 public static int NumberOf1(int n) { int count = 0; for (int i = 0; i < 32; i++) { if( (n & 1) == 1){ count++; } n = n>>1; } return count; }
public int NumberOf1(int n) {
    int a = 0;
    while (n != 0) {
        if ((n & 1) == 1) {
            a++;
        }
        n = n>>>1;
    }
    return a;
} public class Solution {
    public int NumberOf1(int n) {
        // 定义计数器
        int count=0;
        // int类型是32位,所以循环32次
        for(int i=0;i<32;i++){
            // 每一次都要检查末位是否为1
            if( (n&1)==1 ){
                count++;
            }
            // 右移一位
            n = n>>1;
        }
        return count;
    }
}
 优化: public class Solution {
    public int NumberOf1(int n) {
        // 定义计数器
        int count=0;
        // int类型是32位,所以循环32次
        while(n!=0){
            // 每一次都要检查末位是否为1
            if( (n&1)==1 ){
                count++;
            }
            // 右移一位(使用无符号右移,补码最高位补0而不是1,所以最多循环32次)
            n = n>>>1;
        }
        return count;
    }
} 
public class Solution { //从n的2进制形式的最右边开始判断是不是1 /* * 该解法如果输入时负数会陷入死循环, * 因为负数右移时,在最高位补得是1 * 二本题最终目的是求1的个数,那么会有无数个 * 1了。 */ //-------------可能陷入死循环的解法--------------------- public static int NumberOf1_CanNotUse(int n) { int count = 0; while (n != 0) { /* * 用1和n进行位与运算, * 结果要是为1则n的2进制形式 * 最右边那位肯定是1,否则为0 */ if ((n & 1) == 1) { count++; } //把n的2进制形式往右推一位 n = n >> 1; } return count; } //---------------正解-------------------------------- //思想:用1(1自身左移运算,其实后来就不是1了)和n的每位进行位与,来判断1的个数 private static int NumberOf1_low(int n) { int count = 0; int flag = 1; while (flag != 0) { if ((n & flag) != 0) { count++; } flag = flag << 1; } return count; } //--------------------最优解---------------------------- public static int NumberOf1(int n) { int count = 0; while (n != 0) { ++count; n = (n - 1) & n; } return count; } public static void main(String[] args) { //使用n=10,二进制形式为1010,则1的个数为2; int n = -10; System.out.println(n + "的二进制中1的个数:" + NumberOf1(n)); } }