国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

java數據結構和算法學習之漢諾塔示例

2019-11-26 15:42:47
字體:
來源:轉載
供稿:網友

復制代碼 代碼如下:

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)
        }

    }
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 云南省| 兴海县| 商城县| 兰坪| 彰武县| 内黄县| 尉氏县| 蚌埠市| 江陵县| 民勤县| 彰武县| 大渡口区| 梓潼县| 花莲县| 屯昌县| 夏邑县| 阳春市| 莲花县| 武鸣县| 东宁县| 周口市| 吴忠市| 海口市| 健康| 同心县| 淮滨县| 昆明市| 兴隆县| 苏尼特左旗| 辰溪县| 白玉县| 江北区| 年辖:市辖区| 枣庄市| 宝兴县| 山东| 锡林浩特市| 通州区| 普兰县| 临朐县| 宁武县|