欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python實現(xiàn)dijkstra最短路由算法

 更新時間:2019年01月17日 15:06:33   作者:葉赫那拉坤  
這篇文章主要為大家詳細介紹了python實現(xiàn)dijkstra最短路由算法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

Dijkstra算法:又稱迪杰斯特拉算法,迪杰斯特拉算法是由荷蘭計算機科學家狄克斯特拉于1959 年提出的,因此又叫狄克斯特拉算法。是從一個頂點到其余各頂點的最短路徑算法,解決的是有向圖中最短路徑問題。迪杰斯特拉算法主要特點是以起始點為中心向外層層擴展,直到擴展到終點為止百度百科。

注意:Dijkstra算法不能處理包含負邊的圖

# 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)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 樹莓派升級python的具體步驟

    樹莓派升級python的具體步驟

    在本篇文章里小編給大家整理的是關于樹莓派升級python的具體步驟,需要的朋友們可以參考下。
    2020-07-07
  • 解決python明明pip安裝成功卻找不到包的問題

    解決python明明pip安裝成功卻找不到包的問題

    今天小編就為大家分享一篇解決python明明pip安裝成功卻找不到包的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-08-08
  • Jmeter并發(fā)執(zhí)行Python 腳本的完整流程

    Jmeter并發(fā)執(zhí)行Python 腳本的完整流程

    這篇文章主要介紹了Jmeter并發(fā)執(zhí)行 Python 腳本的問題詳解,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09
  • Django自定義分頁效果

    Django自定義分頁效果

    這篇文章主要為大家詳細介紹了Django自定義分頁效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • Python關于迭代器的使用

    Python關于迭代器的使用

    這篇文章主要介紹了Python關于迭代器的使用,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • tensorflow之并行讀入數(shù)據(jù)詳解

    tensorflow之并行讀入數(shù)據(jù)詳解

    今天小編就為大家分享一篇tensorflow之并行讀入數(shù)據(jù)詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-02-02
  • 如何用Python來搭建一個簡單的推薦系統(tǒng)

    如何用Python來搭建一個簡單的推薦系統(tǒng)

    這篇文章主要介紹了如何用Python來搭建一個簡單的推薦系統(tǒng),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-08-08
  • Selenium操作隱藏的元素及問題解決方案

    Selenium操作隱藏的元素及問題解決方案

    這篇文章主要介紹了Selenium操作隱藏的元素及問題解決方案,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-12-12
  • 如何配置關聯(lián)Python 解釋器 Anaconda的教程(圖解)

    如何配置關聯(lián)Python 解釋器 Anaconda的教程(圖解)

    這篇文章主要介紹了如何配置關聯(lián)Python 解釋器 Anaconda的教程,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習火鍋工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04
  • Python將數(shù)據(jù)生成二維碼的四種方法實例代碼

    Python將數(shù)據(jù)生成二維碼的四種方法實例代碼

    二維碼在日常生活中非常常見,廣泛應用于支付、登錄驗證、信息分享等場景,下面這篇文章主要給大家介紹了關于Python將數(shù)據(jù)生成二維碼的四種方法,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-09-09

最新評論