Reverse Bits with Group Reversals

Reverse Bits with Group Reversals

Solution: Multiple Group Reversals

abcdefgh -> efghabcd -> ghefcdab -> hgfedcba

Swap first 16 bits with last 16 bits. Then swap first 8 and last 8 within each 16-bit group. Keep going until individual bits swap. This reverses the entire bit sequence.

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;
}

#bit-manipulation