激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

腳本之家,腳本語(yǔ)言編程技術(shù)及教程分享平臺(tái)!
分類導(dǎo)航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務(wù)器之家 - 腳本之家 - Python - Python數(shù)據(jù)結(jié)構(gòu)與算法之圖的最短路徑(Dijkstra算法)完整實(shí)例

Python數(shù)據(jù)結(jié)構(gòu)與算法之圖的最短路徑(Dijkstra算法)完整實(shí)例

2020-12-24 00:28hanahimi Python

這篇文章主要介紹了Python數(shù)據(jù)結(jié)構(gòu)與算法之圖的最短路徑(Dijkstra算法),結(jié)合完整實(shí)例形式分析了Python圖的最短路徑算法相關(guān)原理與實(shí)現(xiàn)技巧,需要的朋友可以參考下

本文實(shí)例講述了Python數(shù)據(jù)結(jié)構(gòu)與算法之圖的最短路徑(Dijkstra算法)。分享給大家供大家參考,具體如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
# coding:utf-8
# Dijkstra算法——通過(guò)邊實(shí)現(xiàn)松弛
# 指定一個(gè)點(diǎn)到其他各頂點(diǎn)的路徑——單源最短路徑
# 初始化圖參數(shù)
G = {1:{1:0, 2:1, 3:12},
  2:{2:0, 3:9, 4:3},
  3:{3:0, 5:5},
  4:{3:4, 4:0, 5:13, 6:15},
  5:{5:0, 6:4},
  6:{6:0}}
# 每次找到離源點(diǎn)最近的一個(gè)頂點(diǎn),然后以該頂點(diǎn)為重心進(jìn)行擴(kuò)展
# 最終的到源點(diǎn)到其余所有點(diǎn)的最短路徑
# 一種貪婪算法
def Dijkstra(G,v0,INF=999):
 """ 使用 Dijkstra 算法計(jì)算指定點(diǎn) v0 到圖 G 中任意點(diǎn)的最短路徑的距離
  INF 為設(shè)定的無(wú)限遠(yuǎn)距離值
  此方法不能解決負(fù)權(quán)值邊的圖
 """
 book = set()
 minv = v0
 # 源頂點(diǎn)到其余各頂點(diǎn)的初始路程
 dis = dict((k,INF) for k in G.keys())
 dis[v0] = 0
 while len(book)<len(G):
  book.add(minv)         # 確定當(dāng)期頂點(diǎn)的距離
  for w in G[minv]:        # 以當(dāng)前點(diǎn)的中心向外擴(kuò)散
   if dis[minv] + G[minv][w] < dis[w]:   # 如果從當(dāng)前點(diǎn)擴(kuò)展到某一點(diǎn)的距離小與已知最短距離
    dis[w] = dis[minv] + G[minv][w]   # 對(duì)已知距離進(jìn)行更新
  new = INF          # 從剩下的未確定點(diǎn)中選擇最小距離點(diǎn)作為新的擴(kuò)散點(diǎn)
  for v in dis.keys():
   if v in book: continue
   if dis[v] < new:
    new = dis[v]
    minv = v
 return dis
dis = Dijkstra(G,v0=1)
print("服務(wù)器之家測(cè)試結(jié)果:")
print dis.values()

運(yùn)行結(jié)果:

Python數(shù)據(jù)結(jié)構(gòu)與算法之圖的最短路徑(Dijkstra算法)完整實(shí)例

希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。

原文鏈接:https://www.cnblogs.com/hanahimi/p/4692638.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产亚洲在 | 久久久www免费看片 亚洲综合视频一区 | 免费久久久久久 | 成人在线视频精品 | 亚洲第一成网站 | 看一级大毛片 | 91免费高清视频 | 成人午夜毛片 | 中文字幕 日本 | 精品国产一区二区三区久久久蜜月 | av在线在线 | 91看点| 久久免费观看一级毛片 | 久久久成人动漫 | 禁漫天堂久久久久久久久久 | wankz100%videos| 手机免费看一级片 | 狠狠操精品视频 | 国产伦精品一区二区三区 | 久久久久久高清 | 九九热在线视频观看 | 制服丝袜日日夜夜 | 亚洲午夜久久久精品一区二区三区 | 成年人免费视频播放 | 国产午夜精品一区二区三区在线观看 | 黑人三级毛片 | 在线天堂中文在线资源网 | 欧美一级毛片欧美一级成人毛片 | 黄色一级片在线免费观看 | 91av大片 | 国产精品热 | 久久综合九色综合久久久精品综合 | 一级视频在线播放 | 渔夫荒淫艳史 | 中国美女一级黄色片 | 国产午夜精品久久久久婷 | 亚洲日韩中文字幕一区 | 免费毛片儿 | 久久成人国产精品 | 久久99精品久久久久久秒播蜜臀 | 一边吃奶一边插下面 |