整数

185 阅读1分钟

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

Sollution1:暴力

链接:https://www.nowcoder.com/questionTerminal/8ee967e43c2c4ec193b040ea7fbb10b8?answerType=1&f=discussion
来源:牛客网

public class Solution {
    public int NumberOf1(int n) {
         String s=Integer.toBinaryString(n);
        String[] split=s.split("");
        int a=0;
        for(int i = 0; i < split.length; i++) {
            if (split[i].equals("1"))
                {
                    a++;
                }
        }
             return a;
    }
}

Sollution2:利用二进制数的性质

把一个整数减去1,再和原整数做与运算,会把该整数最右边一个1变成0.那么一个整数的二进制有多少个1,就可以进行多少次这样的操作。

链接:https://www.nowcoder.com/questionTerminal/8ee967e43c2c4ec193b040ea7fbb10b8?answerType=1&f=discussion
来源:牛客网

public class Solution {
    public int NumberOf1(int n) {
        int num = 0;
        while (n != 0) {
            num++;
            n &= (n - 1);
        }
        return num;
    }
}

2.整数反转

class Solution {
public:
    int reverse(int x) {
        long res=0;
        while(x!=0){
            int pop=x%10;
            if(res>INT_MAX/10||(res==INT_MAX/10&&pop>7))
            return 0;
            if(res<INT_MIN/10||(res==INT_MIN/10&&pop<-8))
            return 0;
            res=res*10+pop;
            x/=10;
        }
        return res;
    }
};