汉诺塔问题

    技术2023-09-27  96

    汉诺塔问题

    1.汉诺塔问题2.解法3.代码实现

    1.汉诺塔问题

    有三根杆(编号A、B、C),在A杆自下而上、由大到小按顺序放置64个金盘。游戏的目标:把A杆上的金盘全部移到C杆上,并仍保持原有顺序叠好。操作规则:每次只能移动一个盘子,并且在移动过程中三根杆上都始终保持大盘在下,小盘在上,操作过程中盘子可以置于A、B、C任一杆上。

    2.解法

    ① 将 n-1 个盘子从A杆移到B杆上 ② 将1个盘子从A杆移到C杆上 ③ 将 n-1 个盘子从B杆移到C杆上

    3.代码实现
    package com.ilqjx.csdn; public class Hanoi { public static void move(int n, String from, String buffer, String to) { if (n == 1) { System.out.println(from + " -> " + to); return; } move(n - 1, from, to, buffer); move(1, from, buffer, to); move(n - 1, buffer, from, to); } public static void main(String[] args) { move(3, "A", "B", "C"); } }

    执行结果:

    A -> C A -> B C -> B A -> C B -> A B -> C A -> C
    Processed: 0.021, SQL: 9