亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python基于回溯法子集樹(shù)模板實(shí)現(xiàn)圖的遍歷功能示例

 更新時(shí)間:2017年09月05日 11:50:47   作者:羅兵  
這篇文章主要介紹了Python基于回溯法子集樹(shù)模板實(shí)現(xiàn)圖的遍歷功能,結(jié)合實(shí)例形式分析了Python使用回溯法子集樹(shù)模板針對(duì)圖形遍歷問(wèn)題的相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例講述了Python基于回溯法子集樹(shù)模板實(shí)現(xiàn)圖的遍歷功能。分享給大家供大家參考,具體如下:

問(wèn)題

一個(gè)圖:

A --> B
A --> C
B --> C
B --> D
B --> E
C --> A
C --> D
D --> C
E --> F
F --> C
F --> D

從圖中的一個(gè)節(jié)點(diǎn)E出發(fā),不重復(fù)地經(jīng)過(guò)所有其它節(jié)點(diǎn)后,回到出發(fā)節(jié)點(diǎn)E,稱為一條路徑。請(qǐng)找出所有可能的路徑。

分析

將這個(gè)圖可視化如下:

本問(wèn)題涉及到圖,那首先要考慮圖用那種存儲(chǔ)結(jié)構(gòu)表示。鄰接矩陣、鄰接表、...都不太熟。

前面這篇文章http://chabaoo.cn/article/122927.htm有一種最簡(jiǎn)潔的鄰接表表示方式。

接下來(lái)對(duì)問(wèn)題本身進(jìn)行分析:

顯然,問(wèn)題的解的長(zhǎng)度是固定的,亦即所有的路徑長(zhǎng)度都是固定的:n(不回到出發(fā)節(jié)點(diǎn)) 或 n+1(回到出發(fā)節(jié)點(diǎn))

每個(gè)節(jié)點(diǎn),都有各自的鄰接節(jié)點(diǎn)。

對(duì)某個(gè)節(jié)點(diǎn)來(lái)說(shuō),它的所有鄰接節(jié)點(diǎn),可以看作這個(gè)節(jié)點(diǎn)的狀態(tài)空間。遍歷其狀態(tài)空間,剪枝,深度優(yōu)先遞歸到下一個(gè)節(jié)點(diǎn)。搞定!

至此,很明顯套用回溯法子集樹(shù)模板。

代碼:

'''
圖的遍歷
從一個(gè)節(jié)點(diǎn)出發(fā),不重復(fù)地經(jīng)過(guò)所有其它節(jié)點(diǎn)后,回到出發(fā)節(jié)點(diǎn)。找出所有的路徑
'''
# 用鄰接表表示圖
n = 6 # 節(jié)點(diǎn)數(shù)
a,b,c,d,e,f = range(n) # 節(jié)點(diǎn)名稱
graph = [
  {b,c},
  {c,d,e},
  {a,d},
  {c},
  {f},
  {c,d}
]
x = [0]*(n+1) # 一個(gè)解(n+1元數(shù)組,長(zhǎng)度固定)
X = []     # 一組解
# 沖突檢測(cè)
def conflict(k):
  global n,graph,x
  # 第k個(gè)節(jié)點(diǎn),是否前面已經(jīng)走過(guò)
  if k < n and x[k] in x[:k]:
    return True
  # 回到出發(fā)節(jié)點(diǎn)
  if k == n and x[k] != x[0]:
    return True
  return False # 無(wú)沖突
# 圖的遍歷
def dfs(k): # 到達(dá)(解x的)第k個(gè)節(jié)點(diǎn)
  global n,a,b,c,d,e,f,graph,x,X
  if k > n: # 解的長(zhǎng)度超出,已走遍n+1個(gè)節(jié)點(diǎn) (若不回到出發(fā)節(jié)點(diǎn),則 k==n)
    print(x)
    #X.append(x[:])
  else:
    for node in graph[x[k-1]]: # 遍歷節(jié)點(diǎn)x[k]的鄰接節(jié)點(diǎn)(x[k]的所有狀態(tài))
      x[k] = node
      if not conflict(k): # 剪枝
        dfs(k+1)
# 測(cè)試
x[0] = e # 出發(fā)節(jié)點(diǎn)
dfs(1)  # 開(kāi)始處理解x中的第2個(gè)節(jié)點(diǎn)

效果圖:

更多關(guān)于Python相關(guān)內(nèi)容可查看本站專題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python Socket編程技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進(jìn)階經(jīng)典教程》及《Python文件與目錄操作技巧匯總

希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • Django模型中字段屬性choice使用說(shuō)明

    Django模型中字段屬性choice使用說(shuō)明

    這篇文章主要介紹了Django模型中字段屬性choice使用說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-03-03
  • 詳解Python中string模塊除去Str還剩下什么

    詳解Python中string模塊除去Str還剩下什么

    這篇文章主要介紹了詳解Python中string模塊除去Str還剩下什么,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • Python算法之求n個(gè)節(jié)點(diǎn)不同二叉樹(shù)個(gè)數(shù)

    Python算法之求n個(gè)節(jié)點(diǎn)不同二叉樹(shù)個(gè)數(shù)

    本文先向大家分享了建立二叉樹(shù)的簡(jiǎn)單代碼,其次介紹了Python計(jì)算n個(gè)節(jié)點(diǎn)不同二叉樹(shù)個(gè)數(shù)的問(wèn)題及實(shí)現(xiàn)代碼示例,具有一定參考價(jià)值,需要的朋友可以了解下。
    2017-10-10
  • TensorFlow2.X使用圖片制作簡(jiǎn)單的數(shù)據(jù)集訓(xùn)練模型

    TensorFlow2.X使用圖片制作簡(jiǎn)單的數(shù)據(jù)集訓(xùn)練模型

    這篇文章主要介紹了TensorFlow2.X使用圖片制作簡(jiǎn)單的數(shù)據(jù)集訓(xùn)練模型,本文通過(guò)截圖實(shí)例代碼相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-04-04
  • 對(duì)python中的for循環(huán)和range內(nèi)置函數(shù)詳解

    對(duì)python中的for循環(huán)和range內(nèi)置函數(shù)詳解

    下面小編就為大家分享一篇對(duì)python中的for循環(huán)和range內(nèi)置函數(shù)詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-04-04
  • django輸出html內(nèi)容的實(shí)例

    django輸出html內(nèi)容的實(shí)例

    今天小編就為大家分享一篇django輸出html內(nèi)容的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-05-05
  • Python簡(jiǎn)繁體轉(zhuǎn)換的簡(jiǎn)單實(shí)現(xiàn)步驟

    Python簡(jiǎn)繁體轉(zhuǎn)換的簡(jiǎn)單實(shí)現(xiàn)步驟

    工作中需要將繁體中文轉(zhuǎn)換成簡(jiǎn)體中文上網(wǎng)找了些資料,下面這篇文章主要給大家介紹了關(guān)于Python實(shí)現(xiàn)簡(jiǎn)繁體轉(zhuǎn)換的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06
  • python可變對(duì)象,不可變對(duì)象詳解

    python可變對(duì)象,不可變對(duì)象詳解

    這篇文章主要介紹了Python可變對(duì)象和不可變對(duì)象的相關(guān)資料,文中講解非常細(xì)致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2021-09-09
  • Django模板之基本的 for 循環(huán) 和 List內(nèi)容的顯示方式

    Django模板之基本的 for 循環(huán) 和 List內(nèi)容的顯示方式

    這篇文章主要介紹了Django模板之基本的 for 循環(huán) 和 List內(nèi)容的顯示方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-03-03
  • Python實(shí)現(xiàn)批量繪制遙感影像數(shù)據(jù)的直方圖

    Python實(shí)現(xiàn)批量繪制遙感影像數(shù)據(jù)的直方圖

    這篇文章主要為大家詳細(xì)介紹了如何基于Python中g(shù)dal模塊,實(shí)現(xiàn)對(duì)大量柵格圖像批量繪制直方圖,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下
    2023-02-02

最新評(píng)論