1. O(logn)
public static int reverse(int i) {
// HD, Figure 7-1
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;
}
public class Solution {
// you need treat n as an unsigned value
public int reverseBits(int n) {
int result = 0;
for (int i = 0; i < 32; ++i) {
result = (result << 1) + (n & 1);
n = n >> 1;
}
return result;
}
}
3. O(n/2)
// Reverse Bits
// Time Complexity: O(logn), Space Complexity: O(1)
public class Solution {
// you need treat n as an unsigned value
public int reverseBits(int n) {
int left = 0;
int right = 31;
while (left < right) {
// swap bit
int x = (n >> left) & 1;
int y = (n >> right) & 1;
if (x != y) {
n ^= (1 << left) | (1 << right);
}
++left;
--right;
}
return n;
}
}