欢迎来到天天文库
浏览记录
ID:61278366
大小:327.50 KB
页数:8页
时间:2021-01-23
《数据结构(Java版)图3(最短路径)电子教案.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、数据结构(Java版)图3(最短路径)Dijkstra算法思想问题的提法:给定一个带权有向图D与源点v,求从v到D中其它顶点的最短路径。限定各边上的权值大于或等于0。为求得这些最短路径,Dijkstra提出按路径长度的递增次序,逐步产生最短路径的算法。首先求出长度最短的一条最短路径,再参照它求出长度次短的一条最短路径,依次类推,直到从顶点v到其它各顶点的最短路径全部求出为止Dijkstra逐步求解的过程10432101003050206010源点终点最短路径路径长度v0v1(v0,v1)10v2(v0,v1,v2)(v0,v3,v2),60,
2、50v3(v0,v3)30v4(v0,v4)(v0,v3,v4)(v0,v3,v2,v4)100,90,60引入辅助数组dist。它的每一个分量dist[i]表示当前找到的从源点v0到终点vi的最短路径的长度。初始状态:若从源点v0到顶点vi有边,则dist[i]为该边上的权值;若从源点v0到顶点vi无边,则dist[i]为。假设S是已求得的最短路径的终点的集合,则可证明:下一条最短路径必然是从v0出发,中间只经过S中的顶点便可到达的那些顶点vx(vxV-S)的路径中的一条。每次求得一条最短路径后,其终点vk加入集合S,然后对所有的viV
3、-S,修改其dist[i]值。Dijkstra算法设计①初始化:S←{v0};dist[j]←Edge[0][j],j=1,2,…,n-1;//n为图中顶点个数②求出最短路径的长度:dist[k]←min{dist[i]},iV-S;S←SU{k};③修改:dist[i]←min{dist[i],dist[k]+Edge[k][i]},对于每一个iV-S;④判断:若S=V,则算法结束,否则转②。Dijkstra算法中各辅助数组的最终结果从表中读取源点0到终点v的最短路径的方法:举顶点4为例path[4]=2path[2]=3path[3]=
4、0,反过来排列,得到路径0,3,2,4,这就是源点0到终点4的最短路径。04123105010206030100程序运行结果此课件下载可自行编辑修改,仅供参考!感谢您的支持,我们努力做得更好!谢谢
此文档下载收益归作者所有