欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解python百行有效代碼實(shí)現(xiàn)漢諾塔小游戲(簡(jiǎn)約版)

 更新時(shí)間:2020年10月30日 14:25:44   作者:我不是禿頭哆唻咪  
這篇文章主要介紹了詳解python百行有效代碼實(shí)現(xiàn)漢諾塔小游戲(簡(jiǎn)約版),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

直接上代碼:

#左中右塔用一個(gè)列表存儲(chǔ)
left = list()
center = list()
right = list()
"""
初始化函數(shù)
"""
def init():
  size = input("(請(qǐng)友善輸入整數(shù),未寫判斷!)請(qǐng)輸入層數(shù):")
  #初始化塔列表,如5層 左邊塔放 1-3-5-7-9,中間和右邊放5個(gè)-1
  for i in range(1,int(size) + 1):
    left.append(i*2-1)
    center.append(-1)
    right.append(-1)
  return int(size)
"""
打印樣式函數(shù)
"""
def printStyling(i,size,ta):
  if ta[i] != -1:
    # 打印前空格
    for kong in range(int(size - (ta[i] - 1) / 2)):
      print(" ", end="")
    # 打印塔元素
    for le in range(ta[i]):
      print("X", end="")
    # 打印后空格
    for kong in range(int(size - (ta[i] - 1) / 2)):
      print(" ", end="")
  # 左塔這一層為空格
  else:
    # 打印前面空格
    for kong in range(size):
      print(" ", end="")
    # 打印中間的棒棒
    print("|", end="")
    # 打印后面的空格
    for kong in range(size):
      print(" ", end="")
"""
控制臺(tái)打印結(jié)果
"""
def show(size):
  #修飾
  print("-"*35)
  #循環(huán)層數(shù)等于size
  for i in range(size):
    # 打印左邊塔
    printStyling(i,size,left)
    # 打印中間塔
    printStyling(i,size,center)
    # 打印右邊塔
    printStyling(i,size,right)
    #每行打印一個(gè)換行
    print()
  #修飾
  print("-" * 35)
"""
判斷可不可以移動(dòng)
takeOff減少,putOn增加,size層數(shù),tSize和pSize剩余空間
"""
def judge(takeOff,putOn,size,tSize,pSize,count):
  # 如果左塔的空間空的,就是沒有元素可移動(dòng)
  if takeOff == size:
    print("操作無效!")
    return 0
  # 如果中塔為空,可以移動(dòng)
  if pSize == size:
    # 中間的最后一個(gè)元素賦上左塔的第一個(gè)元素的值
    putOn[pSize - 1] = takeOff[tSize]
    # 左塔的第一個(gè)元素賦值-1
    takeOff[tSize] = -1
    # 左塔的剩余空間+1
    tSize += 1
    # 中塔的剩余空間-1
    pSize -= 1
    #步數(shù)+1
    count += 1
    #移動(dòng)成功,返回剩余空間和步數(shù)
    return tSize,pSize,count
  # 如果中塔最上方元素比左塔最上方元素大,即可以移動(dòng)
  elif putOn[pSize] > takeOff[tSize]:
    # 中塔當(dāng)前最上方元素的再上一個(gè)元素(-1)賦上左塔最上方元素的值
    putOn[pSize - 1] = takeOff[tSize]
    # 左塔最上方元素賦值-1
    takeOff[tSize] = -1
    # 左塔剩余空間+1
    tSize += 1
    # 中塔剩余空間-1
    pSize -= 1
    #步數(shù)+1
    count += 1
    # 移動(dòng)成功,返回剩余空間和步數(shù)
    return tSize,pSize,count
  # 否則不可以移動(dòng)
  else:
    print("操作無效!")
    return 0
"""
主要運(yùn)行函數(shù)
"""
def main():
  #初始化游戲
  size = init()
  # 存放最初的盤剩余空間 lSize左塔 cSize中塔 rSize右塔
  lSize = 0
  cSize = size
  rSize = size
  #存放操作步數(shù)
  count = 0
  #打印游戲介紹
  print("將左塔完整地移到右塔就是勝利!")
  print("左-1 中-2 右-3 退出請(qǐng)輸入:quit")
  print('例如輸入:"1-2"就是將左塔的最上元素放到中塔')
  print("%d層的最佳步數(shù)是%d"%(size,pow(2,size)-1))
  #游戲進(jìn)行
  while True:
    print("當(dāng)前移動(dòng)了%d步"%(count))
    #顯示當(dāng)前塔的狀態(tài)
    show(size)
    #判斷右塔是否沒有剩余空間,沒有即勝利,并退出游戲
    if rSize == 0:
      if count == pow(2,size)-1:
        print("恭喜你使用最少步數(shù)完成漢諾塔!")
      else:
        print("恭喜你只移動(dòng)了%d步完成漢諾塔小游戲!"%(count))
      break
    #獲取玩家操作
    select = input("請(qǐng)操作:")
    #左塔移中塔
    if select == "1-2":
      result = judge(left,center,size,lSize,cSize,count)
      if result == 0:
        continue
      else:
        lSize,cSize,count = result
    #左塔移右塔,下面同樣
    elif select == "1-3":
      result = judge(left, right, size, lSize, rSize,count)
      if result == 0:
        continue
      else:
        lSize, rSize,count = result
    elif select == "2-1":
      result = judge(center, left, size, cSize, lSize,count)
      if result == 0:
        continue
      else:
        cSize, lSize,count = result
    elif select == "2-3":
      result = judge(center, right, size, cSize, rSize,count)
      if result == 0:
        continue
      else:
        cSize, rSize,count = result
    elif select == "3-1":
      result = judge(right, left, size, rSize, lSize,count)
      if result == 0:
        continue
      else:
        rSize, lSize,count = result
    elif select == "3-2":
      result = judge(right, center, size, rSize, cSize,count)
      if result == 0:
        continue
      else:
        rSize, cSize ,count= result
    #輸入quit退出游戲
    elif select == "quit":
      break
    #如果輸入的是其他不識(shí)別的文字,就拜拜
    else:
      print("操作有誤!")
    continue
main()

運(yùn)行結(jié)果:

在這里插入圖片描述

在這里插入圖片描述

在這里插入圖片描述

在這里插入圖片描述

到此這篇關(guān)于詳解python百行有效代碼實(shí)現(xiàn)漢諾塔小游戲(簡(jiǎn)約版)的文章就介紹到這了,更多相關(guān)python 漢諾塔 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • python進(jìn)階之魔術(shù)方法詳解

    python進(jìn)階之魔術(shù)方法詳解

    這篇文章主要為大家介紹了python進(jìn)階之魔術(shù)方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-01-01
  • python如何做代碼性能分析

    python如何做代碼性能分析

    這篇文章主要介紹了python如何做代碼性能分析,幫助大家更好的理解和學(xué)習(xí)使用python,感興趣的朋友可以了解下
    2021-04-04
  • 用Python逐行分析文件方法

    用Python逐行分析文件方法

    在本篇文章里我們給大家分享了關(guān)于用Python逐行分析文件方法知識(shí)點(diǎn),有需要的朋友們跟著學(xué)習(xí)下。
    2019-01-01
  • Django發(fā)送郵件功能實(shí)例詳解

    Django發(fā)送郵件功能實(shí)例詳解

    在本篇文章里小編給大家整理了關(guān)于Django發(fā)送郵件功能的詳細(xì)內(nèi)容,有需要的朋友們可以參考學(xué)習(xí)下。
    2019-09-09
  • PyCharm配置anaconda環(huán)境的步驟詳解

    PyCharm配置anaconda環(huán)境的步驟詳解

    PyCharm是一款很好用很流行的python編輯器。Anaconda通過管理工具包、開發(fā)環(huán)境、Python版本,大大簡(jiǎn)化了你的工作流程。今天通過本文給大家分享PyCharm配置anaconda環(huán)境,感興趣的朋友一起看看吧
    2020-07-07
  • python 數(shù)據(jù)的清理行為實(shí)例詳解

    python 數(shù)據(jù)的清理行為實(shí)例詳解

    這篇文章主要介紹了python 數(shù)據(jù)的清理行為實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-07-07
  • python環(huán)境搭建和pycharm的安裝配置及漢化詳細(xì)教程(零基礎(chǔ)小白版)

    python環(huán)境搭建和pycharm的安裝配置及漢化詳細(xì)教程(零基礎(chǔ)小白版)

    這篇文章主要介紹了python環(huán)境搭建和pycharm的安裝配置及漢化(零基礎(chǔ)小白版),需要的朋友可以參考下
    2020-08-08
  • 淺談numpy 函數(shù)里面的axis參數(shù)的含義

    淺談numpy 函數(shù)里面的axis參數(shù)的含義

    這篇文章主要介紹了numpy 函數(shù)里面的axis參數(shù)的含義,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-05-05
  • python實(shí)現(xiàn)獲取當(dāng)前設(shè)備的地點(diǎn)位置

    python實(shí)現(xiàn)獲取當(dāng)前設(shè)備的地點(diǎn)位置

    這篇文章主要介紹了python實(shí)現(xiàn)獲取當(dāng)前設(shè)備的地點(diǎn)位置,電腦如何獲取當(dāng)前所處的地理位置?它不會(huì)像我們一樣對(duì)地理位置有感性的認(rèn)知,它只認(rèn)識(shí)數(shù)據(jù),簡(jiǎn)言之,電腦可以通過獲取當(dāng)前連接的公網(wǎng)IP,反推所處的位置環(huán)境,需要的朋友可以參考一下
    2022-03-03
  • wxPython事件驅(qū)動(dòng)實(shí)例詳解

    wxPython事件驅(qū)動(dòng)實(shí)例詳解

    這篇文章主要介紹了wxPython事件驅(qū)動(dòng)機(jī)制,以一個(gè)獲取當(dāng)前位置信息的實(shí)例形式講述了wxPython事件驅(qū)動(dòng)機(jī)制及其相關(guān)函數(shù)的用法,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2014-09-09

最新評(píng)論