Python設計模式 - 圖搜索模式

class?GraphSearch:

????"""

????在python模擬圖搜索模式

????"""

????def?__init__(self,?graph):

????????self.graph?=?graph

????def?find_path(self,?start,?end,?path=None):

????????path?=?path?or?[]

????????path.append(start)

????????if?start?==?end:

????????????return?path

????????for?node?in?self.graph.get(start,?[]):

????????????if?node?not?in?path:

????????????????newpath?=?self.find_path(node,?end,?path)

????????????????if?newpath:

????????????????????return?newpath

????def?find_all_path(self,?start,?end,?path=None):

????????path?=?path?or?[]

????????path.append(start)

????????if?start?==?end:

????????????return?[path]

????????paths?=?[]

????????for?node?in?self.graph.get(start,?[]):

????????????if?node?not?in?path:

????????????????newpaths?=?self.find_all_path(node,?end,?path[:])

????????????????paths.extend(newpaths)

????????return?paths

????def?find_shortest_path(self,?start,?end,?path=None):

????????path?=?path?or?[]

????????path.append(start)

????????if?start?==?end:

????????????return?path

????????shortest?=?None

????????for?node?in?self.graph.get(start,?[]):

????????????if?node?not?in?path:

????????????????newpath?=?self.find_shortest_path(node,?end,?path[:])

????????????????if?newpath:

????????????????????if?not?shortest?or?len(newpath)?<?len(shortest):

????????????????????????shortest?=?newpath

????????return?shortest

#圖用法的例子

graph?=?{'A':?['B',?'C'],

?????????'B':?['C',?'D'],

?????????'C':?['D'],

?????????'D':?['C'],

?????????'E':?['F'],

?????????'F':?['C']

?????????}

#新的圖形搜索對象的初始化

graph1?=?GraphSearch(graph)

print(graph1.find_path('A',?'D'))

print(graph1.find_all_path('A',?'D'))

print(graph1.find_shortest_path('A',?'D'))

?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容