算法 | Leetcode 190 颠倒二进制位

颠倒给定的 32 位无符号整数的二进制位。

示例 1:

输入: 00000010100101000001111010011100

输出: 00111001011110000010100101000000

解释: 输入的二进制串 00000010100101000001111010011100 表示无符号整数 43261596,因此返回 964176192,其二进制表示形式为 00111001011110000010100101000000。

示例 2:

输入:11111111111111111111111111111101

输出:10111111111111111111111111111111

解释:输入的二进制串 11111111111111111111111111111101 表示无符号整数 4294967293,因此返回 3221225471 其二进制表示形式为 10101111110010110010011101101001。

提示:

请注意,在某些语言(如 Java)中,没有无符号整数类型。在这种情况下,输入和输出都将被指定为有符号整数类型,并且不应影响您的实现,因为无论整数是有符号的还是无符号的,其内部的二进制表示形式都是相同的。
在 Java 中,编译器使用二进制补码记法来表示有符号整数。因此,在上面的 示例 2 中,输入表示有符号整数 -3,输出表示有符号整数 -1073741825。

题解:
public class Solution {
    // you need treat n as an unsigned value
    public int reverseBits(int n) {
        // return Integer.reverse(n);
        int res = 0;
        for(int i=0;i<=31;i++){
            int temp = n >> i; //一位一位来
            temp &= 1;  //取出最低位
            temp <<= (31-i); //颠倒,左移到前面
            res |= temp; //累加
            // res += ((n>>i)&1)<<(31-i);
        }
        return res;

        //Java里的Integer.reserve()源代码
        /***
            public static int reverseBits(int i) {
                    i = (i & 0x55555555) << 1 | (i >>> 1) & 0x55555555;
                    i = (i & 0x33333333) << 2 | (i >>> 2) & 0x33333333;
                    i = (i & 0x0f0f0f0f) << 4 | (i >>> 4) & 0x0f0f0f0f;
                    i = (i << 24) | ((i & 0xff00) << 8) |
                            ((i >>> 8) & 0xff00) | (i >>> 24);
                    return i;
                }

       ***/
    }
}

猜你喜欢

转载自blog.csdn.net/CYK5201995/article/details/106408394