算法介绍
迪科斯彻算法使用了广度优先搜索解决赋权有向图或者无向图的单源最短路径问题,算法最终得到一个最短路径树。该算法常用于路由算法或者作为其他图算法的一个子模块。
当然目前也有人将它用来处理物流方面,以获取代价最小的运送方案。
算法思路
Dijkstra算法采用的是一种贪心的策略。
1.首先,声明一个数组dis来保存源点到各个顶点的最短距离和一个保存已经找到了最短路径的顶点的集合T。
2.其次,原点 s 的路径权重被赋为 0 (dis[s] = 0)。若对于顶点 s 存在能直接到达的边(s,m),则把dis[m]设为w(s, m),同时把所有其他(s不能直接到达的)顶点的路径长度设为无穷大。初始时,集合T只有顶点s。
3.从dis数组选择最小值,则该值就是源点s到该值对应的顶点的最短路径,并且把该点加入到T中,此时完成一个顶点。
4.再次,看看新加入的顶点是否可以到达其他顶点并且看看通过该顶点到达其他点的路径长度是否比源点直接到达短,如果是,那么就替换这些顶点在dis中的值。
5.最后,从dis中找出最小值,重复上述动作,直到T中包含了图的所有顶点(可以到达的)。
算法图形演示
现在有图如下:
每个线的权重以及标识如图所示。
第一步:
建立dis数组和T数组。
首先从起点A 开始,将A可以直接到达的顶点的权重记录在dis数组中,无法直达的记录无穷大(当前使用FFFF表示无穷大)。
将当前选择的顶点加入数组T:
第二步:
从dis数组中选择一个不在T数组中的顶点的最小权重值的顶点,当前选择为B顶点,并将B可以直接到达的顶点的相关权重和当前dis中的权重值比较,如果当前dis权重值大,则替换:
将B加入数组T:
第三步:
依次选择顶点C:
将C加入数组T:
第四步:
依次选择顶点D:
将D加入数组T:
第五步:
依次选择顶点E:
将E加入数组T:
第六步:
依次选择顶点F:
将F加入数组T:
因为所有的顶点都已经在T数组中了,算法结束。
这样就求得了从A点到各个顶点的最优解。
可以看到A顶点无法直达F顶点。
代码表示:
(代码中使用999代表FFF)
#encoding:utf-8 import copy """ 图的表示方式 邻接矩阵 999代表无限远 """ tuG=[[0, 10, 20, 999, 999, 999], [999, 0, 999, 20, 70, 999], [999, 999, 0, 50, 30, 999], [999, 999, 999, 0, 999, 999], [999, 999, 999, 10, 0, 999], [999, 999, 999, 20, 20, 0]]; tuX = 6; # 设置原点到其他定点的各个距离 dis = copy.deepcopy(tuG[0]); def Dijkstra(G,v0): """ 使用 Dijkstra 算法计算指定点 v0 到图 G 中任意点的最短路径的距离 INF 为设定的无限远距离值 """ t = []; minv = v0; while len(t) <= tuX: t.append(minv); #以当前点的中心向外扩散 for w in range(0, tuX): if dis[minv] + G[minv][w] < dis[w]: dis[w] = dis[minv] + G[minv][w] tmp = 1000; for i in range(0, tuX): tmpFlag = False; for j in range(0, len(t)): if i == t[j]: tmpFlag = True; break; if tmpFlag == True: continue; if tmp > dis[i]: tmp = dis[i]; minv = i; if __name__ == '__main__': Dijkstra(tuG,0); print dis;
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
更新日志
- 雨林唱片《赏》新曲+精选集SACD版[ISO][2.3G]
- 罗大佑与OK男女合唱团.1995-再会吧!素兰【音乐工厂】【WAV+CUE】
- 草蜢.1993-宝贝对不起(国)【宝丽金】【WAV+CUE】
- 杨培安.2009-抒·情(EP)【擎天娱乐】【WAV+CUE】
- 周慧敏《EndlessDream》[WAV+CUE]
- 彭芳《纯色角3》2007[WAV+CUE]
- 江志丰2008-今生为你[豪记][WAV+CUE]
- 罗大佑1994《恋曲2000》音乐工厂[WAV+CUE][1G]
- 群星《一首歌一个故事》赵英俊某些作品重唱企划[FLAC分轨][1G]
- 群星《网易云英文歌曲播放量TOP100》[MP3][1G]
- 方大同.2024-梦想家TheDreamer【赋音乐】【FLAC分轨】
- 李慧珍.2007-爱死了【华谊兄弟】【WAV+CUE】
- 王大文.2019-国际太空站【环球】【FLAC分轨】
- 群星《2022超好听的十倍音质网络歌曲(163)》U盘音乐[WAV分轨][1.1G]
- 童丽《啼笑姻缘》头版限量编号24K金碟[低速原抓WAV+CUE][1.1G]