递归_汉诺塔问题

Posted S-Mustard

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了递归_汉诺塔问题相关的知识,希望对你有一定的参考价值。

public class Tower {
    static int nDisks=3;//盘子的个数
    public static void main(String[] agrs) {
        doTwoers(nDisks, ‘A‘, ‘B‘, ‘C‘);
    }
    //topN表示从上往下数,第topN个盘子,需要从form移动到to上面,innner代表盘子上面的一组盘子需要缓和的地方
    public static void doTwoers(int topN,char from,char inter,char to) {
        if(topN==1)
            System.out.println("Disk 1 from "+ from +" to "+to);
        else {
            doTwoers(topN-1, from, to, inter);
            System.out.println("Disk "+topN+" from "+from+" to "+to);
            doTwoers(topN-1, inter, from, to);
            
        }
    }
    

}

 

以上是关于递归_汉诺塔问题的主要内容,如果未能解决你的问题,请参考以下文章

python数据结构_递归_汉诺塔问题

python汉诺塔非递归

递归_汉诺塔问题

python_递归实现汉诺塔

编程:递归编程解决汉诺塔问题(用java实现)

算法笔记_013:汉诺塔问题(Java递归法和非递归法)