java数据结构和算法学习之汉诺塔示例

2022-10-18,,,

这篇文章主要介绍了java数据结构算法中的汉诺塔示例,需要的朋友可以参考下

复制代码 代码如下:
package com.tiantian.algorithms;
/**
 *    _|_1              |                |
 *   __|__2             |                |
 *  ___|___3            |                |            (1).把A上的4个木块移动到C上。
 * ____|____4           |                |
 *     A                B                C
 *
 *     |                |                |
 *     |               _|_1              |
 *     |              __|__2             |            要完成(1)的效果,必须要把1、2、3木块移动到B,这样才能把4移动到C
 * ____|____4        ___|___3            |            如:代码中的“调用(XX)”
 *     A                B                C
 *    
 *     |                |                |
 *     |               _|_1              |
 *     |              __|__2             |            此时,题目就变成了把B上的3个木块移动到C上,回到了题目(1)
 *     |             ___|___3        ____|____4        如:代码中的“调用(YY)”
 *     A                B                C
 *    
 *     然后循环这个过程
 *
 * @author wangjie
 * @version 创建时间:2013-3-4 下午4:09:53
 */
public class HanoiTowerTest {
    public static void main(String[] args) {
        doTowers(4, 'A', 'B', 'C');
    }

    public static void doTowers(int topN, char from, char inter, char to){
        if(topN == 1){
            System.out.println("最后把木块1从" + from + "移动到" + to);
        }else{
            doTowers(topN - 1, from, to, inter); // 调用(XX)
            System.out.println("把木块" + topN + "从" + from + "移动到" + to);
            doTowers(topN - 1, inter, from ,to); // 调用(YY)
        }

    }
}

您可能感兴趣的文章:

  • java数据结构与算法之中缀表达式转为后缀表达式的方法
  • Java数据结构及算法实例:考拉兹猜想 Collatz Conjecture
  • Java数据结构及算法实例:快速计算二进制数中1的个数(Fast Bit Counting)
  • Java数据结构及算法实例:冒泡排序 Bubble Sort
  • Java数据结构及算法实例:朴素字符匹配 Brute Force
  • Java数据结构与算法入门实例详解

《java数据结构和算法学习之汉诺塔示例.doc》

下载本文的Word格式文档,以方便收藏与打印。