亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

c#漢諾塔的遞歸算法與解析

2020-01-24 03:33:54
字體:
來源:轉載
供稿:網友

從左到右 A  B  C 柱 大盤子在下, 小盤子在上, 借助B柱將所有盤子從A柱移動到C柱, 期間只有一個原則: 大盤子只能在小盤子的下面.

如果有3個盤子, 大中小號, 越小的越在上面, 從上面給盤子按順序編號 1(小),2(中),3(大), 后面的原理解析引用這里的編號.

小時候玩過這個游戲, 基本上玩到第7個,第8個就很沒有耐心玩了,并且操作的動作都幾乎相同覺得無聊.  后來學習編程, 認識到遞歸, 用遞歸解決漢諾塔的算法也是我除了簡單的排序算法后學習到的第一種算法.

至于遞歸,簡單來說就是方法內部自己調用自己, 同時也一定有一個結束點. 如果對方法調用棧了解的話,其實是很容易理解方法的調用過程的, 就是從主線程開始調用方法進行不停的壓棧和出棧操作. 方法的調入就是將方法壓入棧中, 方法的結束就是方法出棧的過程, 這樣保證了方法調用的順序流. 如果跟蹤遞歸的調用情況會發現也是如此, 到最后一定是這個方法最后從棧中彈出回到主線程, 并且結束.

棧的特點:先進后出。 比如一個方法 A 自己調用自己, 我用編號區分一下進棧過程:

A -> A(1) -> A(2) -> A(3)

在A(3)時滿足某種條件得以退出, 回到 A(2), A(2)結束回到A(1), 再回到A, 出棧過程:

A(3) -> A(2) -> A(1) -> A

對于遞歸,還有一個形象的認識,就是我小時候家里有一個柜子, 柜子兩端都是玻璃, 頭伸進柜子看一面鏡子,會看到鏡子里還有鏡子, 然后鏡子里還有鏡子, 但和遞歸的特點不同的是這鏡子的反射是沒有盡頭的, 只要眼睛一直能看到底的話.

了解完遞歸后, 再回頭來看如何用遞歸的方式解決漢諾塔的問題.

案例 1 - 假設只有一個盤子的時候, 盤子數量 N=1

只有一個步驟   將第1個盤子從A移動到C, 為了對比方便我這樣來描述這個步驟:

步驟  盤子編號 從柱子移動   移動到柱子

1       1                A               C

案例 2 - 如果有兩個盤子, 盤子數量 N = 2

步驟  盤子編號 從柱子移動   移動到柱子

1              1                A               B

2              2                A               C

3              1                B               C

案例 3  - 如果有三個盤子, 盤子數量 N = 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個盤子的移動到3個盤子的移動, 在移動記錄中,當盤子的編號和盤子數量相同的時候他們的步驟都是從A移動到C (看加粗的部分),其它的步驟對等.

再觀察第3個案例中的第 1-3 步 和 第 5-7步

第 1-3 步 目的是從 A 移動到 B   如果我們把 B 當作終點, 那么這里的第 1-3 步理解起來和 第2個案例的三個步驟完全相同, 都是通過一個柱子來移動,和第2個案例比起來在后面加括號來表示

1       1     A           C     ( A -> B)

2       2     A        B     ( A -> C)

3       1              C           B      ( B -> C)

總結:將盤子B變成C即可.

第 5-7 步 目的是從 B 移動到 C   如果我們把 C 當作終點, 那么這里的 5-7 步理解起來和上面也是一樣的, 和第2個案例的三個步驟也完全相同.和第2個案例比起來就是:

5       1       B           A    ( A -> B)

6       2       B           C    ( A- > C)

7       1       A           C    ( B -> C)

總結: 將盤子B變成A即可

根據這個演示可以明確幾點規律:

1. 當盤子只有一個的時候,只有一個動作 從 A 移動到 C 即結束.

2. 當有N個盤子的時候, 中間的動作都是從 A 移動到 C, 那么表示最下面的第N個盤子移動完畢

3. 中間動作之上都可以認為是: 從 A 移動到 B

4. 中間動作之下都可以認為是: 從 B 移動到 C

2,3,4 可以表示為

1       1                A               B

2       2                A               C

3       1                B               C

這種結構一直在重復進行,C#不太熟悉,試著寫寫,就有了以下代碼:

復制代碼 代碼如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace DataStructure
{
    class HanoiTower
    {

        public void MoveDisk(int DiskQuantity,string PositionA, string PositionB, string PositionC)
        {  
            // If there's only one disk, then end.
            if (DiskQuantity == 1)
            {
                Console.WriteLine("Move disk from position {0} to {1}.",  PositionA, PositionC);
                // Must return
                return;
            }
            else
            {
                // Step 1 - Change B to C  (A --> B)
                MoveDisk(DiskQuantity - 1, PositionA,PositionC,PositionB);
                // Step 2 - No changes     (A --> C)
                MoveDisk(1, PositionA, PositionB, PositionC);
                // Step 3 - Change B to A  (A --> C)
                MoveDisk(DiskQuantity - 1, PositionB, PositionA, PositionC);
            }
        }

        static void Main(string[] args)
        {
            HanoiTower hanoi = new HanoiTower();

            Console.WriteLine("Please input Disk Quantity:");
            int DiskQuantity = Convert.ToInt32(Console.ReadLine());

            hanoi.MoveDisk(DiskQuantity, "A", "B", "C");

            Console.ReadKey();
        }
    }
}

結合上面的分析,最重要的就是這里的3步交換動作, 中間從 A到C的動作是最底層盤子的最終操作.

 // Step 1 - Change B to C  (A --> B)
 MoveDisk(DiskQuantity - 1, PositionA,PositionC,PositionB);
 // Step 2 - No changes     (A --> C)
 MoveDisk(1, PositionA, PositionB, PositionC);
 // Step 3 - Change B to A  (A --> C)
 MoveDisk(DiskQuantity - 1, PositionB, PositionA, PositionC);
 至于第1個參數為什么是DiskQuantity - 1,或者1 大家再回到上面看看是不是所有的步驟都是.. 1.     1,2,1.    1,2,1,3,1,2,1 這種以盤子數對稱的結構,而它前后都是重復1,2,1 的過程.

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产综合香蕉五月婷在线| 成人欧美一区二区三区黑人孕妇| 日韩高清av在线| 欧美成年人视频网站欧美| 久久视频在线免费观看| 久久男人资源视频| 欧美日韩国产第一页| 午夜精品久久久久久久男人的天堂| 亚洲精品成人久久久| xxxxxxxxx欧美| 日韩欧美999| 国产精品揄拍一区二区| 国产精品日本精品| 国产v综合ⅴ日韩v欧美大片| 国产日韩中文字幕在线| 97碰碰碰免费色视频| 亚洲激情久久久| 91免费精品视频| 国产一区二区黄| 97色在线视频| 国产91ⅴ在线精品免费观看| 亚洲va欧美va国产综合剧情| 7m精品福利视频导航| 成人性教育视频在线观看| 综合欧美国产视频二区| 久久久久亚洲精品| 日韩欧美在线看| 成人国产精品久久久久久亚洲| 欧美一区二三区| 国内精品视频久久| 日韩黄色高清视频| 精品久久久999| 在线播放日韩专区| 久久久久久久久久久久久久久久久久av| 久久久久久久久爱| 欧美成人性生活| 91精品国产91久久久久久| 亚洲人成在线观看网站高清| 欧美成人黑人xx视频免费观看| 欧美高清视频一区二区| 97精品伊人久久久大香线蕉| 久久久久久久影院| 国产视频亚洲视频| 97avcom| 国产美女久久精品香蕉69| 国产成人a亚洲精品| 亚洲国产天堂久久国产91| 情事1991在线| 国产日韩精品在线观看| 亚洲人成在线一二| 国产最新精品视频| 亚洲成人教育av| 国产精品福利久久久| 亚洲精品福利在线| 国产成人精品国内自产拍免费看| 91香蕉国产在线观看| 国产视频亚洲精品| 97视频免费在线观看| 亚洲成色www8888| 国产精品视频网站| 国产v综合ⅴ日韩v欧美大片| 国产精品爽爽爽| 97在线免费观看| 日韩中文字幕国产| 国产精品视频公开费视频| 久久人人爽人人爽人人片亚洲| 欧美成人在线网站| 欧美麻豆久久久久久中文| 国产在线a不卡| 丁香五六月婷婷久久激情| 97国产在线视频| 亚洲欧美一区二区激情| 欧美高清视频一区二区| 揄拍成人国产精品视频| 亚洲美女激情视频| 日韩欧美在线免费| 最近更新的2019中文字幕| 国产一区二区三区在线播放免费观看| 亚洲伊人第一页| 在线色欧美三级视频| 日韩有码视频在线| 亚洲第一区在线观看| 97免费视频在线| 日韩美女av在线免费观看| 欧美日韩国产精品专区| 国产精品成人免费视频| 国产一区二区激情| 亚洲自拍偷拍网址| 欧美成人午夜激情视频| 亚洲bt天天射| 中文字幕亚洲综合久久筱田步美| 欧美一级片久久久久久久| 伊人伊人伊人久久| 亚洲激情视频网站| 久久久之久亚州精品露出| 91精品在线一区| 亚洲欧美制服另类日韩| 国产精品99久久久久久久久久久久| 88国产精品欧美一区二区三区| 国产日韩欧美电影在线观看| 亚洲精品美女网站| 国产精品一二区| 国产不卡在线观看| 久久综合伊人77777| 国产精品久久久久久久久粉嫩av| 国产成人精品优优av| 中文字幕亚洲一区二区三区| 国产精品∨欧美精品v日韩精品| 久久人人看视频| 国产欧美日韩精品专区| 91丝袜美腿美女视频网站| 国产精品美女免费视频| 成人亲热视频网站| 欧美另类xxx| 日韩精品极品在线观看播放免费视频| 最近2019年中文视频免费在线观看| 精品国产91久久久久久| 欧美成人免费在线视频| 色噜噜久久综合伊人一本| 国内伊人久久久久久网站视频| 91精品久久久久久久久中文字幕| 亚洲美女性视频| 亚洲欧美日韩一区二区在线| 欧美高清一级大片| 欧美性xxxx极品hd欧美风情| 欧美性猛交xxxxx免费看| 欧美日韩高清在线观看| 亚洲美女又黄又爽在线观看| 国产精品久久久久久久电影| 国产欧美va欧美va香蕉在线| 国产精品免费久久久| 国产精品视频xxxx| 亚洲精品国产免费| 久久久久久久久久av| 色婷婷av一区二区三区在线观看| 亚洲视频在线免费观看| 亚洲香蕉成人av网站在线观看| 欧美日韩高清区| 欧美激情在线一区| 亚洲精品一区中文字幕乱码| 日韩美女写真福利在线观看| 91精品国产综合久久久久久蜜臀| 国产精品激情自拍| 在线播放国产一区中文字幕剧情欧美| 亚洲成年网站在线观看| 亚洲精品中文字幕女同| 91国产精品91| 亚洲一区二区在线| 亚洲国语精品自产拍在线观看| 国产精品福利久久久| 精品二区三区线观看| 国产精品成人国产乱一区| 久久久久久一区二区三区| 一区国产精品视频| 综合136福利视频在线| 欧美孕妇毛茸茸xxxx| 久久久噜噜噜久久久| 久久精品国产亚洲| 高清欧美性猛交xxxx黑人猛交| 精品欧美aⅴ在线网站| 国产91精品网站| 久久久久国产视频| 91在线国产电影| 久久精品美女视频网站|