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

python實(shí)現(xiàn)漢諾塔算法

 更新時(shí)間:2021年03月01日 14:29:20   作者:冬日新雨  
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)漢諾塔算法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

題目:

漢諾塔給出最優(yōu)解,如果對(duì)漢諾塔的定義有不了解,請(qǐng)翻看數(shù)據(jù)結(jié)構(gòu)教材。

除了最基本的之外,還有一題,給定一個(gè)數(shù)組,arr=[2,3,1,2,3],其含義是這是一個(gè)有5個(gè)圓盤(pán)的漢諾塔,每一個(gè)數(shù)字代表這個(gè)圓盤(pán)所在的位置,1代表左邊的柱子,2代表中間,3代表右邊。給出這個(gè)序列代表了漢諾塔移動(dòng)的第幾步,如果該步驟是錯(cuò)誤的,則返回-1,所謂錯(cuò)誤,是指該步驟不是最簡(jiǎn)便的得到漢諾塔序列的操作步驟。

分析:

1、 算法當(dāng)然還是遞歸解了,即把n個(gè)漢諾塔盤(pán)子分解成 n - 1 個(gè)盤(pán)子的移動(dòng)和一個(gè)底層盤(pán)子的移動(dòng),這樣一來(lái),問(wèn)題就成了一連串的遞歸,然后就可以逐步求解了。
當(dāng)然了,漢諾塔還有進(jìn)階問(wèn)題,此處先不討論,隨后補(bǔ)上吧。

2、 這個(gè)步驟的循環(huán)是從最右邊開(kāi)始的,考察最大的圓盤(pán),因?yàn)閿?shù)組的索引值越大,其圓盤(pán)的半徑越大。
這樣一來(lái),如果最大的圓盤(pán)的值為3,說(shuō)明已經(jīng)移動(dòng)到位了,如果為1,說(shuō)明還沒(méi)有開(kāi)始移動(dòng)底層圓盤(pán),如果為2,說(shuō)明圓盤(pán)移動(dòng)到了中間,表示移動(dòng)錯(cuò)誤,因?yàn)楦静恍枰苿?dòng)到中間,這個(gè)步驟是多余的。

代碼:

#!usr/bin/python2.7
# -*- coding=utf8 -*-
# @Time : 18-1-3 下午9:52
# @Author : Cecil Charlie


class Hanoi(object):
 """
 漢諾塔問(wèn)題,給定三個(gè)盤(pán)子,用計(jì)算機(jī)計(jì)算出來(lái)將所有的盤(pán)子從左移動(dòng)到右的所有的操作。
 """
 def __init__(self):
 self.place = ["left", "middle", "right"]
 self.num = 0 # 表示所有操作的總次數(shù)

 def hanoi(self, n):
 """
  給定一個(gè)n,即漢諾塔的盤(pán)子數(shù)量,返回所有的從左移動(dòng)到右側(cè)的具體操作步數(shù)
 :param n: 盤(pán)子數(shù)
 :return: 具體操作
 """
 self.num = 0
 if n > 0:
  self.__move(n, "left", "middle", "right")

 def __move(self, n, start, mid, end):
 if n == 1:
  print "move from " + start + " to " + end
  self.num += 1
 else:
  self.__move(n-1, start, end, mid)
  self.__move(1, start, mid, end)
  self.__move(n-1, mid, start, end)

 def step(self, arr):
 """
  求解針對(duì)arr的圓盤(pán),所對(duì)應(yīng)的最優(yōu)解到底是第幾步。解題的核心在于從右向左考察圓盤(pán)到底在不在3位置,如果在,則說(shuō)明已經(jīng)移動(dòng)成功了;
  如果在中間,說(shuō)明移動(dòng)出現(xiàn)了錯(cuò)誤,因?yàn)椴恍枰苿?dòng)到中間,如果還在左邊,則仍需要考慮。
 :param arr: 列表中每一項(xiàng)表示該項(xiàng)的圓盤(pán)在哪個(gè)柱子上,取值包括1,2,3。1表示左,2表示中,3表示右,索引值越大,表示的圓盤(pán)的半徑越大。
 :return: 屬于最優(yōu)解的第幾步
 """
 if arr is None:
  return -1
 for i in xrange(len(arr) - 1):
  if arr[i] != 1 and arr[i] != 2 and arr[i] != 3:
  return -1
 return self.__process(arr, len(arr)-1, 1, 2, 3)

 def __process(self, arr, i, start, mid, end):
 """
  具體操作得到arr屬于第幾步
 :param arr: 圓盤(pán)對(duì)應(yīng)的位置數(shù)組列表
 :param i: 考察arr圓盤(pán)的第幾個(gè),最大值是 len(arr)-1
 :return: 返回步數(shù),如果給出的arr的位置不是移動(dòng)的最優(yōu)解,則返回 -1。
 """
 if i == -1:
  return 0
 if arr[i] != start and arr[i] != end:
  return -1
 if arr[i] == start:
  return self.__process(arr, i-1, start, end, mid) # 說(shuō)明其值還未過(guò)半,直接找之前的就好
 else: # 說(shuō)明步數(shù)已經(jīng)過(guò)半了。
  count = self.__process(arr, i-1, mid, start, end)
  if count == -1:
  return -1
  return (i * 2) + count

h = Hanoi()
h.hanoi(4)
print h.num
print h.step([3,3,2,1])

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 淺談優(yōu)化Django ORM中的性能問(wèn)題

    淺談優(yōu)化Django ORM中的性能問(wèn)題

    這篇文章主要介紹了淺談優(yōu)化Django ORM中的性能問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-07-07
  • Python 解決logging功能使用過(guò)程中遇到的一個(gè)問(wèn)題

    Python 解決logging功能使用過(guò)程中遇到的一個(gè)問(wèn)題

    這篇文章主要介紹了Python 解決logging功能使用過(guò)程中遇到的一個(gè)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-04-04
  • 詳解Python讀取yaml文件多層菜單

    詳解Python讀取yaml文件多層菜單

    這篇文章主要介紹了Python讀取yaml文件多層菜單,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • Python實(shí)現(xiàn)簡(jiǎn)單求解給定整數(shù)的質(zhì)因數(shù)算法示例

    Python實(shí)現(xiàn)簡(jiǎn)單求解給定整數(shù)的質(zhì)因數(shù)算法示例

    這篇文章主要介紹了Python實(shí)現(xiàn)簡(jiǎn)單求解給定整數(shù)的質(zhì)因數(shù)算法,結(jié)合實(shí)例形式分析了Python正整數(shù)分解質(zhì)因數(shù)的相關(guān)操作技巧,需要的朋友可以參考下
    2018-03-03
  • PyQt5 加載圖片和文本文件的實(shí)例

    PyQt5 加載圖片和文本文件的實(shí)例

    今天小編就為大家分享一篇PyQt5 加載圖片和文本文件的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-06-06
  • Python監(jiān)聽(tīng)鍵盤(pán)和鼠標(biāo)事件的示例代碼

    Python監(jiān)聽(tīng)鍵盤(pán)和鼠標(biāo)事件的示例代碼

    這篇文章主要介紹了Python監(jiān)聽(tīng)鍵盤(pán)和鼠標(biāo)事件的示例代碼,幫助大家更好的理解和使用python,提高辦公效率,感興趣的朋友可以了解下
    2020-11-11
  • Numpy之如何改變數(shù)組形狀

    Numpy之如何改變數(shù)組形狀

    這篇文章主要介紹了Numpy之如何改變數(shù)組形狀問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • django-filter和普通查詢的例子

    django-filter和普通查詢的例子

    今天小編就為大家分享一篇django-filter和普通查詢的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-08-08
  • python中的print()輸出

    python中的print()輸出

    print() 方法用于打印輸出,最常見(jiàn)的一個(gè)函數(shù)。這篇文章主要介紹了python的print()輸出 ,需要的朋友可以參考下
    2019-04-04
  • Python 運(yùn)行.py文件和交互式運(yùn)行代碼的區(qū)別詳解

    Python 運(yùn)行.py文件和交互式運(yùn)行代碼的區(qū)別詳解

    這篇文章主要介紹了Python 運(yùn)行.py文件和交互式運(yùn)行代碼的區(qū)別詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07

最新評(píng)論