implementation of tower_of_hanoi algorithm (#756)

This commit is contained in:
WILFRIED NJANGUI 2019-04-14 13:58:16 +02:00 committed by John Law
parent 52d2fbf3cf
commit b2f1d9c337

24
maths/Hanoi.py Normal file
View File

@ -0,0 +1,24 @@
# @author willx75
# Tower of Hanoi recursion game algorithm is a game, it consists of three rods and a number of disks of different sizes, which can slide onto any rod
import logging
log = logging.getLogger()
logging.basicConfig(level=logging.DEBUG)
def Tower_Of_Hanoi(n, source, dest, by, mouvement):
if n == 0:
return n
elif n == 1:
mouvement += 1
# no print statement (you could make it an optional flag for printing logs)
logging.debug('Move the plate from', source, 'to', dest)
return mouvement
else:
mouvement = mouvement + Tower_Of_Hanoi(n-1, source, by, dest, 0)
logging.debug('Move the plate from', source, 'to', dest)
mouvement = mouvement + 1 + Tower_Of_Hanoi(n-1, by, dest, source, 0)
return mouvement