前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >汉诺塔问题

汉诺塔问题

作者头像
半月无霜
发布2023-03-03 14:59:51
3130
发布2023-03-03 14:59:51
举报
文章被收录于专栏:半月无霜

汉诺塔问题

一、介绍

汉诺塔(Tower of Hanoi),又称河内塔,是一个源于印度古老传说的益智玩具。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。

大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。介绍来源于百度知道

image-20220907171931209
image-20220907171931209

我小时候也玩过,但当时就是云里雾里的,不知道怎么去解题,简单的可以完成,难的就不行了。

到了现在,如何用代码解题,依旧是一个不小的难度,反正我是得琢磨一会。

二、解题思路

有三根柱子,分别是起始的柱子辅助的柱子目标的柱子,我们需要将圆盘从开始移动到目标。

但由于汉诺塔的这项规则,在小圆盘上不能放大圆盘上,我们就可以将其分为两部分,分为上面一部分,下面一部分。

下面一部分永远比上面一部分要大,所以需要先将上面这一部分移动到辅助的位置。

当上面这部分有多个时,照样看成上下两部分,上面部分移动到辅助位置(最开始的目标位置,现在变成了辅助位置)

如此重复执行,直到完成所有的迁移。

大家可以先试试这个小游戏,找找灵感

代码如下,主要使用到了递归

代码语言:javascript
复制
package com.banmoon.algorithm.classical;

public class Hanoi {

    public static void main(String[] args) {
        hanoi(3, 'A', 'B', 'C');
    }

    /**
     * 移动汉诺塔
     * @param i 当前的盘子
     * @param from 开始的位置
     * @param assist 辅助的位置
     * @param to 目标的位置
     */
    public static void hanoi(int i, char from, char assist, char to) {
        // 将盘子看成两部分,最下面的一个,和最上面的所有
        if (i == 1) {
            // 如果仅有一个盘子,直接移动即可
            System.out.println(String.format("将第%s个盘子从%s移动到%s", i, from, to));
        }
        else {
            // 将上面的所有移动到,辅助位置(如此一来,辅助位置就变成了此处的目标位置)
            hanoi(i-1, from, to, assist);
            // 将当前的盘子移动到目标位置
            System.out.println(String.format("将第%s个盘子从%s移动到%s", i, from, to));
            // 将目前处于辅助位置的盘子,分成两部分,上面部分移动到原先开始的位置,下面部分移动到目标位置
            hanoi(i-1, assist, from, to);
        }
    }

}

三、最后

三天打鱼,两天晒网,说的就是本人我啦。

我是半月,祝你幸福!!!

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-09-07,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 汉诺塔问题
    • 一、介绍
      • 二、解题思路
        • 三、最后
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档