Python數(shù)據(jù)結構與算法之圖的廣度優(yōu)先與深度優(yōu)先搜索算法示例
本文實例講述了Python數(shù)據(jù)結構與算法之圖的廣度優(yōu)先與深度優(yōu)先搜索算法。分享給大家供大家參考,具體如下:
根據(jù)維基百科的偽代碼實現(xiàn):
廣度優(yōu)先BFS:
使用隊列,集合
標記初始結點已被發(fā)現(xiàn),放入隊列
每次循環(huán)從隊列彈出一個結點
將該節(jié)點的所有相連結點放入隊列,并標記已被發(fā)現(xiàn)
通過隊列,將迷宮路口所有的門打開,從一個門進去繼續(xù)打開里面的門,然后返回前一個門處
""" procedure BFS(G,v) is let Q be a queue Q.enqueue(v) label v as discovered while Q is not empty v ← Q.dequeue() procedure(v) for all edges from v to w in G.adjacentEdges(v) do if w is not labeled as discovered Q.enqueue(w) label w as discovered """ def procedure(v): pass def BFS(G,v0): """ 廣度優(yōu)先搜索 """ q, s = [], set() q.extend(v0) s.add(v0) while q: # 當隊列q非空 v = q.pop(0) procedure(v) for w in G[v]: # 對圖G中頂點v的所有鄰近點w if w not in s: # 如果頂點 w 沒被發(fā)現(xiàn) q.extend(w) s.add(w) # 記錄w已被發(fā)現(xiàn)
深度優(yōu)先DFS
使用 棧,集合
初始結點入棧
每輪循環(huán)從棧中彈出一個結點,并標記已被發(fā)現(xiàn)
對每個彈出的結點,將其連接的所有結點放到隊列中
通過棧的結構,一步步深入挖掘
"""" Pseudocode[edit] Input: A graph G and a vertex v of G Output: All vertices reachable from v labeled as discovered A recursive implementation of DFS:[5] 1 procedure DFS(G,v): 2 label v as discovered 3 for all edges from v to w in G.adjacentEdges(v) do 4 if vertex w is not labeled as discovered then 5 recursively call DFS(G,w) A non-recursive implementation of DFS:[6] 1 procedure DFS-iterative(G,v): 2 let S be a stack 3 S.push(v) 4 while S is not empty 5 v = S.pop() 6 if v is not labeled as discovered: 7 label v as discovered 8 for all edges from v to w in G.adjacentEdges(v) do 9 S.push(w) """ def DFS(G,v0): S = [] S.append(v0) label = set() while S: v = S.pop() if v not in label: label.add(v) procedure(v) for w in G[v]: S.append(w)
更多關于Python相關內(nèi)容感興趣的讀者可查看本站專題:《Python數(shù)據(jù)結構與算法教程》、《Python加密解密算法與技巧總結》、《Python編碼操作技巧總結》、《Python函數(shù)使用技巧總結》、《Python字符串操作技巧匯總》及《Python入門與進階經(jīng)典教程》
希望本文所述對大家Python程序設計有所幫助。
相關文章
Python實現(xiàn)將藍底照片轉(zhuǎn)化為白底照片功能完整實例
這篇文章主要介紹了Python實現(xiàn)將藍底照片轉(zhuǎn)化為白底照片功能,結合完整實例形式分析了Python基于cv2庫進行圖形轉(zhuǎn)換操作的相關實現(xiàn)技巧,需要的朋友可以參考下2019-12-12python爬蟲實現(xiàn)爬取同一個網(wǎng)站的多頁數(shù)據(jù)的實例講解
在本篇文章里小編給大家整理了一篇關于python爬蟲實現(xiàn)爬取同一個網(wǎng)站的多頁數(shù)據(jù)的實例內(nèi)容,有興趣的朋友們可以學習參考下。2021-01-01Python成功解決TypeError: ‘method’ object is
在Python編程中,有時候我們可能會遇到一個讓人摸不著頭腦的錯誤信息:TypeError: 'method' object is not subscriptable,本文給大家介紹了Python如何成功解決TypeError: ‘method’ object is not subscriptable,需要的朋友可以參考下2024-06-06在Python的web框架中編寫創(chuàng)建日志的程序的教程
這篇文章主要介紹了在Python的web框架中編寫創(chuàng)建日志的程序的教程,示例代碼基于Python2.x版本,需要的朋友可以參考下2015-04-04Pytorch反向傳播中的細節(jié)-計算梯度時的默認累加操作
這篇文章主要介紹了Pytorch反向傳播中的細節(jié)-計算梯度時的默認累加操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06