208
社区成员




package test;
public class Demo {
public static int i = 1; // 统计移动次数
public static void hanoi(int num, char s, char t, char x) {
// 如果圆盘数量仅有 1 个,则直接从起始柱移动到目标柱
if (num == 1) {
System.out.println("第" + i + "次:从" + s + "移动到" + t);
i++;
} else {
// 递归调用 hanoi() 函数,将 num-1 个圆盘从起始柱移动到辅助柱上
hanoi(num - 1, s, x, t);
// 将起始柱上剩余的最后一个大圆盘移动到目标柱上
System.out.println("第" + i + "次:从" + s + "移动到" + t);
i++;
// 递归调用 hanoi() 函数,将辅助柱上的 num-1 圆盘移动到目标柱上
hanoi(num - 1, x, t, s);
}
}
public static void main(String[] args) {
hanoi(3, 'A', 'B', 'C');
}
}