颠倒给定的 32 位无符号整数的二进制位:用 C++实现
时间: 2024-02-06 17:10:31 浏览: 29
可以通过移位和按位运算符来实现颠倒给定的32位无符号整数的二进制位。具体实现如下:
```c++
class Solution {
public:
uint32_t reverseBits(uint32_t n) {
uint32_t res = 0;
int power = 31; // 32位整数,最高位为2^31
while (n != 0) {
res += (n & 1) << power; // 通过按位与运算获取最低位,然后左移power位
n = n >> 1; // 右移一位
power--; // power减一
}
return res;
}
};
```
上述代码中,变量 `res` 表示颠倒后的结果,变量 `power` 表示当前位需要左移的位数。在循环中,首先通过按位与运算 `n & 1` 获取最低位,然后将其左移 `power` 位,得到当前位的值,累加到结果中。接着将给定的整数右移一位,继续处理下一位,同时将 `power` 减一,以便下一次左移时向左移动更少的位数,直到所有位都处理完毕。最后返回结果即可。
相关问题
颠倒给定的 32 位无符号整数的二进制位。
好的,我可以回答这个问题。颠倒给定的 32 位无符号整数的二进制位可以通过位运算实现。具体来说,可以使用位移运算和按位与运算。代码如下:
unsigned int reverseBits(unsigned int n) {
unsigned int result = ;
for (int i = ; i < 32; i++) {
result = (result << 1) | (n & 1);
n >>= 1;
}
return result;
}
这个函数接受一个无符号整数 n,返回颠倒后的结果。在循环中,我们不断将 n 的最低位取出来,然后将其放到 result 的最高位。最后返回 result 即可。
颠倒给定的 6 位无符号整数的二进制位。给出java代码和junit测试代码
以下是Java代码:
```
public class ReverseBits {
public static int reverseBits(int n) {
int result = 0;
for (int i = 0; i < 32; i++) {
result <<= 1;
result |= (n & 1);
n >>>= 1;
}
return result;
}
}
```
以下是JUnit测试代码:
```
import org.junit.Test;
import static org.junit.Assert.assertEquals;
public class ReverseBitsTest {
@Test
public void testReverseBits() {
assertEquals(964176192, ReverseBits.reverseBits(43261596));
assertEquals(-1073741825, ReverseBits.reverseBits(-3));
}
}
```
这个程序的主要思路是使用位运算将输入的无符号整数的二进制位颠倒,然后返回结果。JUnit测试代码测试了两个例子,分别是正数和负数,用于验证程序的正确性。