python 實(shí)現(xiàn)漢諾塔游戲
一、漢諾塔問題
1. 問題來源
問題源于印度的一個古老傳說,大梵天創(chuàng)造世界的時候做了三根金剛石柱子,在一根柱子上從下往上按照大小順序摞著64片黃金圓盤。大梵天命令婆羅門把圓盤從下面開始按大小順序重新擺放在另一根柱子上。并且規(guī)定,在小圓盤上不能放大圓盤,在三根柱子之間一次只能移動一個圓盤。
2. 問題闡述
塔內(nèi)有三個座A、B、C,A座上有64個盤子,盤子從上到下逐漸變大,最下面的盤子最大。目前要把A座的64個盤子從A座移到C座,并且每次只能移動一個盤子,移動過程中三個座保持大盤子在下,小盤子在上,要求輸出盤子的移動過程。
二、問題解析
1. 解決方法:遞歸方法
2. 解題過程
(1) 將上面63個盤子從A座移到B座
(2) 將最下面的盤子從A座移到C座
(3) 將B座的63個盤子從B座移到C座
三、問題解決
1. 非可視化解決
(1) 代碼實(shí)現(xiàn)
''' 編程環(huán)境:python3.7 win7x64 '''
def printf(A,C): #盤子移動的輸出格式
print("{} --> {}".format(A,C))
def move(n,A,B,C):
if n == 1:
printf(A,C) #將最后1個盤子從A座移到C座
else:
move(n-1,A,C,B) #將n個盤子從A座借助B座移到C座
printf(A,C) #將最后1個盤子從A座移到C座
move(n-1,B,A,C) #將n個盤子從B座借助A座移到C座
N = int(input("請輸入漢諾塔層數(shù):"))
move(N,'A','B','C')
(2) 有圖有真相

2. 可視化解決
(1) 代碼實(shí)現(xiàn)
''' 編程環(huán)境:python3.7 win7x64 '''
from turtle import *
class Stack:
def __init__(self):
self.items = []
def isEmpty(self):
return len(self.items) == 0
def push(self, item):
self.items.append(item)
def pop(self):
return self.items.pop()
def peek(self):
if not self.isEmpty():
return self.items[len(self.items) - 1]
def size(self):
return len(self.items)
def drawpole_1(k):#畫漢諾塔的底座
up()
pensize(10)
speed(100)
goto(400*(k-1), 100)
down()
goto(400*(k-1), -100)
goto(400*(k-1)-20, -100)
goto(400*(k-1)+20, -100)
def drawpole_3():#畫出漢諾塔的三個底座
hideturtle()#隱藏
drawpole_1(0)#畫出漢諾塔的底座左
drawpole_1(1)#畫出漢諾塔的底座中
drawpole_1(2)#畫出漢諾塔的底座右
def creat_plates(n):#制造n個盤子
plates=[Turtle() for i in range(n)]
for i in range(n):
plates[i].up()
plates[i].hideturtle()
plates[i].shape("square")
plates[i].shapesize(1,8-i)
plates[i].goto(-400,-90+20*i)
plates[i].showturtle()
return plates
def pole_stack():#制造底座的棧
poles=[Stack() for i in range(3)]
return poles
def moveDisk(plates,poles,fp,tp):#把poles[fp]頂端的盤子plates[mov]從poles[fp]移到poles[tp]
mov=poles[fp].peek()
plates[mov].goto((fp-1)*400,150)
plates[mov].goto((tp-1)*400,150)
l=poles[tp].size()#確定移動到底部的高度(恰好放在原來最上面的盤子上面)
plates[mov].goto((tp-1)*400,-90+20*l)
def moveTower(plates,poles,height,fromPole, toPole, withPole):#遞歸放盤子
if height >= 1:
moveTower(plates,poles,height-1,fromPole,withPole,toPole)
moveDisk(plates,poles,fromPole,toPole)
poles[toPole].push(poles[fromPole].pop())
moveTower(plates,poles,height-1,withPole,toPole,fromPole)
myscreen=Screen()
setup(1200,500) #設(shè)置窗口大小
drawpole_3() #畫漢諾塔的底座
n=int(input("請輸入漢諾塔的層數(shù)并回車:"))#輸入漢諾塔的盤子數(shù)
plates=creat_plates(n)#制造n個盤子
poles=pole_stack()
for i in range(n):
poles[0].push(i)
moveTower(plates,poles,n,0,2,1)
myscreen.exitonclick()
(2) 有圖有真相

以上就是python 實(shí)現(xiàn)漢諾塔游戲的詳細(xì)內(nèi)容,更多關(guān)于python 漢諾塔游戲的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Python與Matlab混合編程的實(shí)現(xiàn)案例
本文主要介紹了Python與Matlab混合編程的實(shí)現(xiàn)案例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01
Python實(shí)現(xiàn)比較兩個文件夾中代碼變化的方法
這篇文章主要介紹了Python實(shí)現(xiàn)比較兩個文件夾中代碼變化的方法,實(shí)例分析了Python讀取文件夾中文件及字符串操作的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-07-07
Python3.5常見內(nèi)置方法參數(shù)用法實(shí)例詳解
這篇文章主要介紹了Python3.5常見內(nèi)置方法參數(shù)用法,結(jié)合實(shí)例形式詳細(xì)分析了Python常見的內(nèi)置方法及參數(shù)使用技巧,需要的朋友可以參考下2019-04-04
詳解向scrapy中的spider傳遞參數(shù)的幾種方法(2種)
這篇文章主要介紹了詳解向scrapy中的spider傳遞參數(shù)的幾種方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
Python count()函數(shù)實(shí)例詳解
count() 是Python的內(nèi)置函數(shù),可以「統(tǒng)計(jì)」字符串里指定「字符」或指定字符串出現(xiàn)的「次數(shù)」,這篇文章主要介紹了Python count()函數(shù)詳解,需要的朋友可以參考下2023-07-07

