2017-10-22 20:50:54 +02:00
|
|
|
The Tower of Hanoi (also called the Tower of Brahma or Lucas' Tower
|
|
|
|
and sometimes pluralized) is a mathematical game or puzzle. It
|
|
|
|
consists of three rods and a number of disks of different sizes,
|
2019-04-10 14:07:01 +02:00
|
|
|
which can slide onto any rod. The puzzle starts with the disks in
|
2017-10-22 20:50:54 +02:00
|
|
|
a neat stack in ascending order of size on one rod, the smallest
|
|
|
|
at the top, thus making a conical shape.
|
|
|
|
|
|
|
|
The objective of the puzzle is to move the entire stack to another
|
|
|
|
rod, obeying the following simple rules:
|
|
|
|
|
|
|
|
- Only one disk can be moved at a time.
|
|
|
|
- Each move consists of taking the upper disk from one of the
|
|
|
|
stacks and placing it on top of another stack.
|
|
|
|
- No disk may be placed on top of a smaller disk.
|
|
|
|
|
|
|
|
With 3 disks, the puzzle can be solved in 7 moves. The minimal
|
|
|
|
number of moves required to solve a Tower of Hanoi puzzle is
|
|
|
|
2^n-1, where n is the number of disks.
|
|
|
|
|
|
|
|
Taken from https://en.m.wikipedia.org/wiki/Tower_of_Hanoi
|
|
|
|
|
|
|
|
~~~
|
2019-04-10 14:07:01 +02:00
|
|
|
{ 'Num 'From 'To 'Via } [ var ] array:for-each
|
2017-10-22 20:50:54 +02:00
|
|
|
|
2019-04-10 14:07:01 +02:00
|
|
|
:set !Via !To !From !Num ;
|
|
|
|
:display @To @From 'Move_a_ring_from_%n_to_%n\n s:format s:put ;
|
2017-10-22 20:50:54 +02:00
|
|
|
|
2017-10-20 21:58:42 +02:00
|
|
|
:hanoi (num,from,to,via-)
|
2019-04-10 14:07:01 +02:00
|
|
|
set @Num n:-zero?
|
|
|
|
[ @Num @From @To @Via
|
|
|
|
@Num n:dec @From @Via @To hanoi set display
|
|
|
|
@Num n:dec @Via @To @From hanoi ] if ;
|
2017-10-20 21:58:42 +02:00
|
|
|
|
2017-10-22 19:45:28 +02:00
|
|
|
#3 #1 #3 #2 hanoi nl
|
2017-10-20 21:58:42 +02:00
|
|
|
~~~
|