Tower of Hanoi
Tower of Hanoi
Tower of Hanoi
Tower of Hanoi
The Objective is to transfer the entire
tower to one of the other pegs.
However you can only move one disk
at a time and you can never stack a
larger disk onto a smaller disk. Try to
solve it in fewest possible moves.
Tower of Hanoi
How to solve the 4 pegs
Tower of Hanoi
Solution
To get a better understanding for the general
algorithm used to solve the Tower of Hanoi, try
to solve the puzzle with a small amount of
disks,
3 or 4, and once you master that , you can
solve
the same puzzle with more discs with the
following algorithm.
Tower of Hanoi
Recursive Solution for the Tower of Hanoi with algorithm
Lets call the three peg Src(Source), Aux(Auxiliary) and
st(Destination).
1) Move the top N 1 disks from the Source to Auxiliary
tower
2) Move the Nth disk from Source to Destination tower
3) Move the N 1 disks from Auxiliary tower to
Destination tower. Transferring the top N 1 disks from
Source to Auxiliary tower can again be thought of as a
fresh problem and can be solved in the same manner.
So once you master solving Tower of Hanoi with three
disks, you can solve it with any number of disks with
the above algorithm.
Tower of Hanoi
The puzzle is well known to students of Computer
Science since it appears in virtually any
introductory text on data structures or algorithms.
A function solve with four arguments (number of
disks) and three pegs (source, intermediary and
destination) could look like this.
Solve (N, Src, Aux, Dst)
If N is 0
Exit
Else solve (N-1, Src, Dst, Aux)
Move from Src to Dst
Solve(N -1 , Aux, Src, Dst)
Tower of Hanoi
This actually serves as the definition of the function Solve. The
function is recursive in that it calls itself repeatedly with decreasing
values of N until a terminating condition (in our case N = 0) has been
met. To me the sheer simplicity of the solution is breathtaking. For
N =3 it translates into
1.
2.
3.
4.
5.
6.
7.
Move
Move
Move
Move
Move
Move
Move
from
from
from
from
from
from
from
Src to Dst
Src to Aux
Dst to Aux
Src to Dst
Aux to Src
Aux to Dst
Src to Dst
Tower of Hanoi
For N = 4 we get the following sequence
1. Move from Src to Aux
2. Move from Src to Dst
3. Move from Aux to Dst
4. Move from Src to Aux
5. Move from Dst to Src
6. Move from Dst to Aux
7. Move from Src to Aux
8. Move from Src to Dst
9. Move from Aux to Dst
10. Move from Aux to Src
11. Move from Dst to Src
12. Move from Aux to Dst
13. Move from Src to Aux
14. Move from Src to Dst
15. Move from Aux to Dst
Tower of Hanoi
How many moves will it take to transfer n disks from the left
post to the right post?
the recursive pattern can help us generate more numbers to
find an explicit (non-recursive) pattern. Here's how to find
the number of moves needed to transfer larger numbers of
disks from post A to post C, remembering that M = the
number of moves needed to transfer n-1 disks from post A to
post C:
for 1 disk it takes 1 move to transfer 1 disk from post A to
post C;
for 2 disks, it will take 3 moves: 2M + 1 = 2(1) + 1 = 3
for 3 disks, it will take 7 moves: 2M + 1 = 2(3) + 1 = 7
for 4 disks, it will take 15 moves: 2M + 1 = 2(7) + 1 = 15
for 5 disks, it will take 31 moves: 2M + 1 = 2(15) + 1 = 31
for 6 disks... ?
Tower of Hanoi
Explicit Pattern
Number of Disks Number of Moves
1 1
2 3
3 7
4 15
5 31
Powers of two help reveal the pattern:
Number of Disks (n) Number of Moves
1 2^1 - 1 = 2 - 1 = 1
2 2^2 - 1 = 4 - 1 = 3
3 2^3 - 1 = 8 - 1 = 7
4 2^4 - 1 = 16 - 1 = 15
5 2^5 - 1 = 32 - 1 = 31