python實現(xiàn)dijkstra最短路由算法
Dijkstra算法:又稱迪杰斯特拉算法,迪杰斯特拉算法是由荷蘭計算機科學(xué)家狄克斯特拉于1959 年提出的,因此又叫狄克斯特拉算法。是從一個頂點到其余各頂點的最短路徑算法,解決的是有向圖中最短路徑問題。迪杰斯特拉算法主要特點是以起始點為中心向外層層擴展,直到擴展到終點為止百度百科。
注意:Dijkstra算法不能處理包含負(fù)邊的圖
# dijkstra算法實現(xiàn),有向圖和路由的源點作為函數(shù)的輸入,最短路徑最為輸出
def dijkstra(graph,src):
# 判斷圖是否為空,如果為空直接退出
if graph is None:
return None
nodes = [i for i in range(len(graph))] # 獲取圖中所有節(jié)點
visited=[] # 表示已經(jīng)路由到最短路徑的節(jié)點集合
if src in nodes:
visited.append(src)
nodes.remove(src)
else:
return None
distance={src:0} # 記錄源節(jié)點到各個節(jié)點的距離
for i in nodes:
distance[i]=graph[src][i] # 初始化
# print(distance)
path={src:{src:[]}} # 記錄源節(jié)點到每個節(jié)點的路徑
k=pre=src
while nodes:
mid_distance=float('inf')
for v in visited:
for d in nodes:
new_distance = graph[src][v]+graph[v][d]
if new_distance < mid_distance:
mid_distance=new_distance
graph[src][d]=new_distance # 進行距離更新
k=d
pre=v
distance[k]=mid_distance # 最短路徑
path[src][k]=[i for i in path[src][pre]]
path[src][k].append(k)
# 更新兩個節(jié)點集合
visited.append(k)
nodes.remove(k)
print(visited,nodes) # 輸出節(jié)點的添加過程
return distance,path
if __name__ == '__main__':
graph_list = [ [0, 2, 1, 4, 5, 1],
[1, 0, 4, 2, 3, 4],
[2, 1, 0, 1, 2, 4],
[3, 5, 2, 0, 3, 3],
[2, 4, 3, 4, 0, 1],
[3, 4, 7, 3, 1, 0]]
distance,path= dijkstra(graph_list, 0) # 查找從源點0開始帶其他節(jié)點的最短路徑
print(distance,path)
節(jié)點的遍歷過程如下:

最短路徑輸出:

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Python數(shù)據(jù)結(jié)構(gòu)與算法之圖的最短路徑(Dijkstra算法)完整實例
- Python使用Dijkstra算法實現(xiàn)求解圖中最短路徑距離問題詳解
- Python實現(xiàn)Dijkstra算法
- python實現(xiàn)Dijkstra靜態(tài)尋路算法
- python實現(xiàn)Dijkstra算法的最短路徑問題
- python Dijkstra算法實現(xiàn)最短路徑問題的方法
- python3實現(xiàn)Dijkstra算法最短路徑的實現(xiàn)
- 一文教你用python編寫Dijkstra算法進行機器人路徑規(guī)劃
- python最短路徑的求解Dijkstra算法示例代碼
相關(guān)文章
用Python自動清理系統(tǒng)垃圾的實現(xiàn)
這篇文章主要介紹了用Python自動清理系統(tǒng)垃圾的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01
Python實現(xiàn)數(shù)據(jù)可視化案例分析
這篇文章主要介紹了Python實現(xiàn)數(shù)據(jù)可視化案例分析,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-08-08
python 使用xlsxwriter循環(huán)向excel中插入數(shù)據(jù)和圖片的操作
這篇文章主要介紹了python 使用xlsxwriter循環(huán)向excel中插入數(shù)據(jù)和圖片的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01
matplotlib.pyplot.plot()參數(shù)使用詳解
這篇文章主要介紹了matplotlib.pyplot.plot()參數(shù)詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07
python統(tǒng)計指定目錄內(nèi)文件的代碼行數(shù)
這篇文章主要介紹了python統(tǒng)計指定目錄內(nèi)文件的代碼行數(shù)2019-09-09
Python字符串和正則表達式中的反斜杠(''\'')問題詳解
在本篇文章里小編給大家整理的是關(guān)于Python字符串和正則表達式中的反斜杠('\')問題以及相關(guān)知識點,有需要的朋友們可以學(xué)習(xí)下。2019-09-09

