Count bits used in int

后端 未结 11 1393
梦谈多话
梦谈多话 2020-12-30 15:54

If you have the binary number 10110 how can I get it to return 5? e.g a number that tells how many bits are used? There are some likewise examples listed below:

11条回答
  •  野趣味
    野趣味 (楼主)
    2020-12-30 16:42

    Easiest?

    32 - Integer.numberOfLeadingZeros(value)
    

    If you are looking for algorithms, the implementors of the Java API agree with your divide-and-conquer bitshifting approach:

    public static int numberOfLeadingZeros(int i) {
        if (i == 0)
            return 32;
        int n = 1;
        if (i >>> 16 == 0) { n += 16; i <<= 16; }
        if (i >>> 24 == 0) { n +=  8; i <<=  8; }
        if (i >>> 28 == 0) { n +=  4; i <<=  4; }
        if (i >>> 30 == 0) { n +=  2; i <<=  2; }
        n -= i >>> 31;
        return n;
    }
    

    Edit: As a reminder to those who trust in the accuracy of floating point calculations, run the following test harness:

    public static void main(String[] args) {
        for (int i = 0; i < 64; i++) {
            long x = 1L << i;
            check(x);
            check(x-1);
        }
    }
    
    static void check(long x) {
        int correct = 64 - Long.numberOfLeadingZeros(x);
        int floated = (int) (1 + Math.floor(Math.log(x) / Math.log(2)));
        if (floated != correct) {
            System.out.println(Long.toString(x, 16) + " " + correct + " " + floated);
        }
    }
    

    The first detected deviation is:

    ffffffffffff 48 49
    

提交回复
热议问题