python實現(xiàn)廣度優(yōu)先搜索過程解析
更新時間:2019年10月19日 10:34:23 作者:水滴月
這篇文章主要介紹了python實現(xiàn)廣度優(yōu)先搜索過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
廣度優(yōu)先搜索
適用范圍: 無權(quán)重的圖,與深度優(yōu)先搜索相比,深度優(yōu)先搜索法占內(nèi)存少但速度較慢,廣度優(yōu)先搜索算法占內(nèi)存多但速度較快
復(fù)雜度: 時間復(fù)雜度為O(V+E),V為頂點數(shù),E為邊數(shù)
思路
廣度優(yōu)先搜索是以層為順序,將某一層上的所有節(jié)點都搜索到了之后才向下一層搜索;
代碼
from collections import deque
#解決從你的人際關(guān)系網(wǎng)中找到芒果銷售商的問題
#使用字典表示映射關(guān)系
graph = {}
graph["you"] = ["alice", "bob", "claire"]
graph["bob"] = ["anuj", "peggy"]
graph["alice"] = ["peggy"]
graph["claire"] = ["thom", "jonny"]
graph["anuj"] = []
graph["peggy"] = []
graph["thom"] = []
graph["jonny"] = []
#判斷是否是要查找的目標(biāo)
def is_target_node(name):
return name[-1] == 'm'
#實現(xiàn)廣度優(yōu)先搜索算法
def search(name):
search_queue = deque() #創(chuàng)建一個隊列
search_queue += graph[name]
searched = [] #記錄用于檢查過的人
while search_queue: #只要隊列不為空
person = search_queue.popleft() #就取出其中的第一個人
if not person in searched: #這個人沒有被檢查過
if is_target_node(person): #判斷這個人是否是要查找的銷售商
print(person + " is target node!")
return True
else:
search_queue += graph[person] #如果這個人不是,就將這個人的朋友壓入隊列
searched.append(person) #將這個人追加到已檢查過的字典中
return False
#調(diào)用方法
search("you")
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- python圖的深度優(yōu)先和廣度優(yōu)先算法實例分析
- 10分鐘教你用python動畫演示深度優(yōu)先算法搜尋逃出迷宮的路徑
- python 遞歸深度優(yōu)先搜索與廣度優(yōu)先搜索算法模擬實現(xiàn)
- python深度優(yōu)先搜索和廣度優(yōu)先搜索
- Python深度優(yōu)先算法生成迷宮
- Python數(shù)據(jù)結(jié)構(gòu)與算法之圖的廣度優(yōu)先與深度優(yōu)先搜索算法示例
- python數(shù)據(jù)結(jié)構(gòu)之圖深度優(yōu)先和廣度優(yōu)先實例詳解
- python廣度優(yōu)先搜索得到兩點間最短路徑
- python實現(xiàn)樹的深度優(yōu)先遍歷與廣度優(yōu)先遍歷詳解
相關(guān)文章
用python統(tǒng)計代碼行的示例(包括空行和注釋)
今天小編就為大家分享一篇用python統(tǒng)計代碼行的示例(包括空行和注釋),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-07-07
Python之a(chǎn)scii轉(zhuǎn)中文的實現(xiàn)
這篇文章主要介紹了Python之a(chǎn)scii轉(zhuǎn)中文的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-05-05

