Home > Algorithm > ハノイの塔アルゴリズム (Tower of Hanoi Algorithm for VB)

ハノイの塔アルゴリズム (Tower of Hanoi Algorithm for VB)


  • Posted by: WebMaster
  • 2008年6月 2日 19:30
  • Algorithm

ハノイの塔は、インドの神話では「ブラフマーの塔」と呼ばれ天地創造のとき神が64枚の金の円盤を重ね、移し替えが終わったときに世界が終焉するといわれたことに由来します(ブラフマー神は創造の神、ヴィシュヌ神は維持の神、シヴァ神は破壊の神)。ルールは下の円盤が常に上に重なる円盤よりも大きな円盤になるようにします。64枚の円盤を移し変えるには最小で264-1回(18,446,744,073,709,551,615回)の移動が必要です。

今回の記事では、その移し変えのアルゴリズムを紹介します。下の画像は3枚のディスクを左のロッドから右のロッドに移し替えた場合のイメージです。

Algorithm of "Tower of Hanoi" which is written by VB as shown below, click "Continue Reading". The images below is how to move the three disks from a left rod to a right rod.



1 hanoi1.png

2 hanoi2.png

3 hanoi3.png

4 hanoi4.png

5 hanoi5.png

6 hanoi6.png

7 hanoi7.png

8 hanoi8.png

ハノイの塔のアルゴリズムのソースコードを2つ紹介します。アルゴリズム自体は同じものです。2番目のソースコードは3本あるロッドの目的地のロッドと間にあるロッドの受け渡しを交互に選択されるように(6 - Start - Dest)と書いてあります。省略された分、コードが簡略化されてます。 最小の移動回数は2N-1 (Nはディスクの数)になります。10枚のディスクのケースでは、210-1=1023回の移動が必要です。20枚の場合はもう3桁増えます。64枚のディスクの場合は2N-1回の移動になります。64枚の場合、プログラムが実行されたら冗談抜きで少なくとも数千年の時間を要することになると思います。VBAで実行してもQueueのスタック領域の制限があるのでエラーになると思います。Java や C などでこのアルゴリズムを実行する際は枚数設定で注意が必要です。

3枚のディスクを移動する場合は以下のようになります。2³-1=7回の移動回数です。1番目のロッドが初期設定の場所で、そこから目的地の3番目のロッドに移動します。(プロシージャを実行するとイミディエイトウィンドウにに表示されます。)

Move Disk(No.1) from 1 to 3 <--ディスク1を1から3に移動
Move Disk(No.2) from 1 to 2
Move Disk(No.1) from 3 to 2
Move Disk(No.3) from 1 to 3
Move Disk(No.1) from 2 to 1
Move Disk(No.2) from 2 to 3
Move Disk(No.1) from 1 to 3

4枚のディスクを移動する場合は以下のようになります。24-1=15回の移動回数です。

Move Disk[No.1] from 1 to 2
Move Disk[No.2] from 1 to 3
Move Disk[No.1] from 2 to 3
Move Disk[No.3] from 1 to 2
Move Disk[No.1] from 3 to 1
Move Disk[No.2] from 3 to 2
Move Disk[No.1] from 1 to 2
Move Disk[No.4] from 1 to 3
Move Disk[No.1] from 2 to 3
Move Disk[No.2] from 2 to 1
Move Disk[No.1] from 3 to 1
Move Disk[No.3] from 2 to 3
Move Disk[No.1] from 1 to 2
Move Disk[No.2] from 1 to 3
Move Disk[No.1] from 2 to 3

Comments:0

Comment Form

Home > Algorithm > ハノイの塔アルゴリズム (Tower of Hanoi Algorithm for VB)

Return to page top