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

网友投稿 257 2022-08-27


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

概述

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

汉诺塔

汉诺塔http:// (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);

} elseYpoqu {

// 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

Ypoqu 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


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Python题库——题目(python试题)
下一篇:第一章:用Pythonic方式来思考(Ⅰ)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~