首页 > 代码库 > 最短路径算法之三——Bellman-Ford算法
最短路径算法之三——Bellman-Ford算法
Bellman-Ford算法
Dijkstra算法无法判断含负权边的图的最短路。
如果遇到负权,在没有负权回路存在时,即便有负权的边,也可以采用Bellman-Ford算法正确求出最短路径。
PS:负权回路的含义是,回路的权值和为负。
算法描述
1.初始化:将除源点外的所有顶点的最短距离估计值 d[v] ←+∞, d[s] ←0;
2.迭代求解:反复对边集E中的每条边进行松弛操作,使得顶点集V中的每个顶点v的最短距离估计值逐步逼近其最短距离;(运行|v|-1次)
3.检验负权回路:判断边集E中的每一条边的两个端点是否收敛。如果存在未收敛的顶点,则算法返回false,表明问题无解;否则算法返回true,并且从源点可达的顶点v的最短距离保存在 d[v]中。
伪代码:
1 For i=1 to |G.V|-12 For each edge(u,v)属于G.E3 RELAX(u,v,w)4 For each edge(u,v)属于G.E5 If (v.d>u.d+w(u,v)6 Return FALSE;7 Return TRUE;
时间复杂度:O(VE) 即顶点数*边数
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。