444、编写一个程序,反转整数值中二进制位的顺序。该程序应从用户处获取输入值,并调用 reverseBits 方法以逆序打印这些位。在反转前后都应打印该值的二进制表示,以确认位是否正确反转。你需要同时实现递归和迭代两种解决方案。
以下是一个 Java 程序,用于反转整数值中二进制位的顺序。它包含递归和迭代两种解决方案:
import java.util.Scanner;
public class ReverseBits {
// 迭代方法反转位
public static int reverseBitsIterative(int n) {
int result = 0;
for (int i = 0; i < 32; i++) {
result <<= 1;
result |= (n & 1);
n >>= 1;
}
return result;
}
// 递归方法反转位
public static int reverseBitsRecursive(int n, int pos) {
if (pos == 0) {
return n;
}
return (reverseBitsRecursive(n >> 1, pos - 1) << 1) | (n & 1);
}
// 打印整数的二进制表示
public static void printBits(int n) {
for (int i = 31; i >= 0; i--) {
System.out.print((n >> i) & 1);
if (i % 8 == 0) {
System.out.print(" ");


322

被折叠的 条评论
为什么被折叠?



