欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

Java 数据结构与算法系列精讲之汉诺塔

时间:2022-11-15 09:47:14|栏目:JAVA代码|点击:

概述

从今天开始, 小白我将带大家开启 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->C
盘2从: A->B
盘1从: C->B
盘3从: A->C
盘1从: B->A
盘2从: B->C
盘1从: A->C

上一篇:Java Maven settings.xml中私有仓库配置详解

栏    目:JAVA代码

下一篇:一文讲解如何优雅的调试jar包

本文标题:Java 数据结构与算法系列精讲之汉诺塔

本文地址:http://www.codeinn.net/misctech/219043.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有