颠倒二进制位(位运算)

题目:颠倒给定的 32 位无符号整数的二进制位。
代码

class Solution {
public:
    uint32_t reverseBits(uint32_t n) {
        n = (n >> 16) | (n << 16);
        n = ((n & 0xff00ff00) >> 8) | ((n & 0x00ff00ff) << 8);
        n = ((n & 0xf0f0f0f0) >> 4) | ((n & 0x0f0f0f0f) << 4);
        n = ((n & 0xcccccccc) >> 2) | ((n & 0x33333333) << 2);
        n = ((n & 0xaaaaaaaa) >> 1) | ((n & 0x55555555) << 1);
        return n;
    }
};
发布了152 篇原创文章 · 获赞 2 · 访问量 6440

猜你喜欢

转载自blog.csdn.net/weixin_43918473/article/details/105352848