【Java 数据结构 & 算法】宁可累死自己, 也要卷死别人 14 汉诺塔

举报
我是小白呀iamarookie 发表于 2021/12/21 22:18:57 2021/12/21
1.6k+ 0 0
【摘要】 【Java 数据结构 & 算法】️⚠️宁可累死自己, 也要卷死别人 14️⚠️ 汉诺塔 概述汉诺塔递归汉诺塔实现 概述 从今天开始, 小白我将带大家开启 Java 数据结构 &am...

【Java 数据结构 & 算法】️⚠️宁可累死自己, 也要卷死别人 14️⚠️ 汉诺塔

概述

从今天开始, 小白我将带大家开启 Java 数据结构 & 算法的新篇章.

在这里插入图片描述

汉诺塔

汉诺塔 (Tower of Hanoi) 是一个源于印度的古老益智玩具. 汉诺塔由三根柱子和若干大小不同的圆盘组成. 目标是把圆盘从最左边的柱子移到最右边的柱子上. 如图:

在这里插入图片描述

递归

递归 (Recursion) 指的是在函数中调用自身. 递归可以帮助我们简化问题, 使用更少的代码达成目标.

在这里插入图片描述

汉诺塔实现

public class 汉诺塔 {

    // 汉诺塔实现
    private static void hanoi(int num, char a, char b, char c) {
        String str = "";

        // 判断是否为最后
        if(num==1) {
            str = "盘1从: " + a + "->" + c;
            System.out.println(str);
        } else {

            // 2^(n-1)次, 把除第n个盘从A移动到B
            hanoi(num - 1, a, c, b);

            str = "盘" + num + "从: " + a + "->" + c;
            System.out.println(str);

            // 2^(n-1)次, 把除第n个盘从B移动到C
            hanoi(num - 1, b, a, c);
        }
    }

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

  
 

输出结果:

1: A->C2: A->B1: C->B3: A->C1: B->A2: B->C1: A->C

  
 

文章来源: iamarookie.blog.csdn.net,作者:我是小白呀,版权归原作者所有,如需转载,请联系作者。

原文链接:iamarookie.blog.csdn.net/article/details/122053932

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

作者其他文章

评论(0

抱歉,系统识别当前为高风险访问,暂不支持该操作

    全部回复

    上滑加载中

    设置昵称

    在此一键设置昵称,即可参与社区互动!

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。