Python基于回溯法子集樹模板實現(xiàn)圖的遍歷功能示例
本文實例講述了Python基于回溯法子集樹模板實現(xiàn)圖的遍歷功能。分享給大家供大家參考,具體如下:
問題
一個圖:
A --> B
A --> C
B --> C
B --> D
B --> E
C --> A
C --> D
D --> C
E --> F
F --> C
F --> D
從圖中的一個節(jié)點E出發(fā),不重復(fù)地經(jīng)過所有其它節(jié)點后,回到出發(fā)節(jié)點E,稱為一條路徑。請找出所有可能的路徑。
分析
將這個圖可視化如下:
本問題涉及到圖,那首先要考慮圖用那種存儲結(jié)構(gòu)表示。鄰接矩陣、鄰接表、...都不太熟。
前面這篇文章http://www.dbjr.com.cn/article/122927.htm有一種最簡潔的鄰接表表示方式。
接下來對問題本身進行分析:
顯然,問題的解的長度是固定的,亦即所有的路徑長度都是固定的:n(不回到出發(fā)節(jié)點) 或 n+1(回到出發(fā)節(jié)點)
每個節(jié)點,都有各自的鄰接節(jié)點。
對某個節(jié)點來說,它的所有鄰接節(jié)點,可以看作這個節(jié)點的狀態(tài)空間。遍歷其狀態(tài)空間,剪枝,深度優(yōu)先遞歸到下一個節(jié)點。搞定!
至此,很明顯套用回溯法子集樹模板。
代碼:
''' 圖的遍歷 從一個節(jié)點出發(fā),不重復(fù)地經(jīng)過所有其它節(jié)點后,回到出發(fā)節(jié)點。找出所有的路徑 ''' # 用鄰接表表示圖 n = 6 # 節(jié)點數(shù) a,b,c,d,e,f = range(n) # 節(jié)點名稱 graph = [ {b,c}, {c,d,e}, {a,d}, {c}, {f}, {c,d} ] x = [0]*(n+1) # 一個解(n+1元數(shù)組,長度固定) X = [] # 一組解 # 沖突檢測 def conflict(k): global n,graph,x # 第k個節(jié)點,是否前面已經(jīng)走過 if k < n and x[k] in x[:k]: return True # 回到出發(fā)節(jié)點 if k == n and x[k] != x[0]: return True return False # 無沖突 # 圖的遍歷 def dfs(k): # 到達(解x的)第k個節(jié)點 global n,a,b,c,d,e,f,graph,x,X if k > n: # 解的長度超出,已走遍n+1個節(jié)點 (若不回到出發(fā)節(jié)點,則 k==n) print(x) #X.append(x[:]) else: for node in graph[x[k-1]]: # 遍歷節(jié)點x[k]的鄰接節(jié)點(x[k]的所有狀態(tài)) x[k] = node if not conflict(k): # 剪枝 dfs(k+1) # 測試 x[0] = e # 出發(fā)節(jié)點 dfs(1) # 開始處理解x中的第2個節(jié)點
效果圖:
更多關(guān)于Python相關(guān)內(nèi)容可查看本站專題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python Socket編程技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進階經(jīng)典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對大家Python程序設(shè)計有所幫助。
相關(guān)文章
Python算法之求n個節(jié)點不同二叉樹個數(shù)
本文先向大家分享了建立二叉樹的簡單代碼,其次介紹了Python計算n個節(jié)點不同二叉樹個數(shù)的問題及實現(xiàn)代碼示例,具有一定參考價值,需要的朋友可以了解下。2017-10-10TensorFlow2.X使用圖片制作簡單的數(shù)據(jù)集訓練模型
這篇文章主要介紹了TensorFlow2.X使用圖片制作簡單的數(shù)據(jù)集訓練模型,本文通過截圖實例代碼相結(jié)合給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-04-04對python中的for循環(huán)和range內(nèi)置函數(shù)詳解
下面小編就為大家分享一篇對python中的for循環(huán)和range內(nèi)置函數(shù)詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-04-04Python簡繁體轉(zhuǎn)換的簡單實現(xiàn)步驟
工作中需要將繁體中文轉(zhuǎn)換成簡體中文上網(wǎng)找了些資料,下面這篇文章主要給大家介紹了關(guān)于Python實現(xiàn)簡繁體轉(zhuǎn)換的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-06-06Django模板之基本的 for 循環(huán) 和 List內(nèi)容的顯示方式
這篇文章主要介紹了Django模板之基本的 for 循環(huán) 和 List內(nèi)容的顯示方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03Python實現(xiàn)批量繪制遙感影像數(shù)據(jù)的直方圖
這篇文章主要為大家詳細介紹了如何基于Python中g(shù)dal模塊,實現(xiàn)對大量柵格圖像批量繪制直方圖,文中的示例代碼講解詳細,感興趣的小伙伴可以了解一下2023-02-02