汉诺塔问题可视化算法(汉诺塔问题-算法面试题)

题目介绍

在经典的汉诺塔问题中,有 3 根柱子及 N 个不同大小的穿孔圆盘,盘子可以滑入任意一根柱子。一开始,所有盘子自上而下按升序依次套在第一根柱子上(即每一个盘子只能放在更大的盘子上面)。移动圆盘时会受到以下限制:

  • 每次只能移动一个盘子;
  • 盘子只能从柱子顶端滑出移到下一根柱子;
  • 盘子只能叠在比它大的盘子上。

请编写程序,用栈将所有盘子从第一根柱子移到最后一根柱子。

题目分析
  • n = 1 时:

汉诺塔问题可视化算法(汉诺塔问题-算法面试题)(1)

start

汉诺塔问题可视化算法(汉诺塔问题-算法面试题)(2)

step1

直接将盘子从pillar1移到pillar3。

  • n = 2 时:

汉诺塔问题可视化算法(汉诺塔问题-算法面试题)(3)

start

汉诺塔问题可视化算法(汉诺塔问题-算法面试题)(4)

step1

step1: 将盘子 1 从 pillar1 移到 pillar2

汉诺塔问题可视化算法(汉诺塔问题-算法面试题)(5)

step2

step2: 将盘子 2 从 pillar1 移到 pillar3

汉诺塔问题可视化算法(汉诺塔问题-算法面试题)(6)

step3

step3: 将盘子 1 从 pillar2 移到 pillar3

  • n = 3 时:

汉诺塔问题可视化算法(汉诺塔问题-算法面试题)(7)

start

汉诺塔问题可视化算法(汉诺塔问题-算法面试题)(8)

step1

step1: 将盘子 1、2 从 pillar1 移到 pillar2(重复 n=2 时的步骤即可)。

汉诺塔问题可视化算法(汉诺塔问题-算法面试题)(9)

step2

step2: 将盘子 3 从 pillar1 移到 pillar3

汉诺塔问题可视化算法(汉诺塔问题-算法面试题)(10)

step3: 将盘子 1 、2 从 pillar2 移到 pillar3

  • 根据上面的例子,我们可以推理出 n 个盘子从 pillar1 移到 pillar3的步骤:

step1: 将盘子 1、2......、n-1 从 pillar1 移到 pillar2

step2: 将盘子 n 从 pillar1 移到 pillar3

step1: 将盘子 1、2......、n-1 从 pillar2 移到 pillar3

代码实现

public class Pillar { private int index; private Stack<Integer> pillar = new Stack<>(); public Pillar(int index){ this.index = index; } public int getIndex(){ return index; } public void add(int disk){ if (!pillar.isEmpty() && disk > pillar.peek()){ System.out.println("Error placing: Disk " disk " is bigger than top disk " pillar.peek()); } else { pillar.push(disk); } } public void moveTopDiskTo(Pillar destination){ if(pillar.isEmpty()){ System.out.println("Error moving: No disk int pillar " index); }else { destination.add(pillar.pop()); } } public void moveToPillar(int n, Pillar destination, Pillar buff){ if(n > 0) { moveToPillar(n - 1, buff, destination); moveTopDiskTo(destination); buff.moveToPillar(n - 1, destination, this); } } public Stack<Integer> disks(){ return pillar; } public static void main(String[] args) { Pillar pillar1 = new Pillar(1); Pillar pillar2 = new Pillar(2); Pillar pillar3 = new Pillar(3); int n = 10; for (int i = n; i > 0 ; i--) { pillar1.add(i); } System.out.println("Start: "); System.out.println("pillar1: " pillar1.disks()); System.out.println("pillar2: " pillar2.disks()); System.out.println("pillar3: " pillar3.disks()); pillar1.moveToPillar(n, pillar3, pillar2); System.out.println("end: "); System.out.println("pillar1: " pillar1.disks()); System.out.println("pillar2: " pillar2.disks()); System.out.println("pillar3: " pillar3.disks()); } }

,

免责声明:本文仅代表文章作者的个人观点,与本站无关。其原创性、真实性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容文字的真实性、完整性和原创性本站不作任何保证或承诺,请读者仅作参考,并自行核实相关内容。