鱼C论坛

 找回密码
 立即注册
查看: 1522|回复: 2

[已解决]汉诺塔递归

[复制链接]
发表于 2022-6-11 09:40:30 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
public class HanoiTower {
    public static void main(String[] args) {
        Tower t1 = new Tower();
        t1.move(8,'a','b','c');

    }
}
class Tower{
    public void move(int num,char a,char b,char c){
        if (num == 1){
            System.out.println(a+"->"+c);
        }else{                         //分两个整体  第一部分是最下面的一个, 第二部分是上面的所有
            move(num-1,a,c,b);   //把上面的部分全部移动到b盘
            System.out.println(a+"->"+c);
            move(num-1,b,a,c); //把b盘的全部移动到c盘
        }
    }
}
我的疑惑时  当num不等于1时,为什么第一个输出的是a->b    a到b我能理解,关键是这个-> 我在方法中没写 ,是哪里来的
最佳答案
2022-6-11 10:03:06
System.out.println(a+"->"+c);
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-6-11 10:03:06 From FishC Mobile | 显示全部楼层    本楼为最佳答案   
System.out.println(a+"->"+c);
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-6-13 00:22:46 | 显示全部楼层
晓得了晓得了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-22 04:43

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表