码迷,mamicode.com
首页 > 编程语言 > 详细

汉诺塔算法的理解

时间:2015-04-18 13:14:14      阅读:180      评论:0      收藏:0      [点我收藏+]

标签:

当盘子数为两个时,移动图如下:

技术分享

移动规律为:

步骤 盘子编号 源柱子 目标柱子
1 1
A B
2 2 A C
3 1 B C

当盘子数为3个时:

技术分享

移动规律为:

步骤 盘子编号 源柱子 目标柱子
1 1 A C
2 2 A B
3 1 C B
4 3 A C
5 1 B A
6 2 B C
7 1 A C

从以上移动移动规律可以总结出,当步骤序号和盘子数目相同时,就是把最底下的盘子从A移动到C,其它的步骤都是对等的,规律如下:

  1. 中间以上动作是:源柱子(A)不变,目标柱子为C,辅助柱子为B进行移动,也就是

    源柱子->目标柱子

    源柱子->辅助柱子

    目标柱子->辅助柱子

  2. 中间动作:从A到C也就是从源柱子到目标柱子

  3. 中间以下动作:源柱子是B,目标柱子为C,辅助柱子为A进行移动,也就是

    源柱子->辅助柱子

    源柱子->目标柱子

    辅助柱子->目标柱子

按照以上规律,可以大概总结出实际上移动的主要动作实际上就是在重复三步动作,用java代码可以表示如下:

/**
 * @author lenovo
 *
 */
public class Hanoi {
    /**
    * 
    * @param n 盘子的数目
    * @param origin 源座
    * @param assist 辅助座
    * @param destination 目的座
    */
    public void hanoi(int n, char origin, char assist, char destination) {
    	if (n >= 1) {
    		hanoi(n - 1, origin, destination, assist);
    		System.out.println("Direction:" + origin + "--->" + destination);
    		hanoi(n - 1, assist, origin, destination);
    	}
    }
 
    public static void main(String[] args) {
        Hanoi hanoi = new Hanoi();
        hanoi.hanoi(3, ‘A‘, ‘B‘, ‘C‘);
    }
}

一开始我理解这个算法的时候老是一直在分析程序的出栈,入栈动作,后面看了这篇文章汉诺塔的递归算法与解析才有点恍然大悟,这个算法实际上是考验对递归思想的理解:总结事物的规律,然后再用程序表达出来。

汉诺塔算法的理解

标签:

原文地址:http://my.oschina.net/u/914897/blog/403306

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!