Bellman_Ford算法

Posted Jason333

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Bellman_Ford算法相关的知识,希望对你有一定的参考价值。

看了别人的博客,总结得很好。http://blog.csdn.net/xu3737284/article/details/8973615

 

Bellman-Ford算法可以大致分为三个部分
第一,初始化所有点。每一个点保存一个值,表示从原点到达这个点的距离,将原点的值设为0,其它的点的值设为无穷大(表示不可达)。
第二,进行循环,循环下标为从1到n-1(n等于图中点的个数)。在循环内部,遍历所有的边,进行松弛计算。
第三,遍历途中所有的边(edge(u,v)),判断是否存在这样情况:
d(v) > d (u) + w(u,v)
则返回false,表示途中存在从源点可达的权为负的回路。

 

注:最短路中一定不含回路,n个顶点的图,最短路最多n-1条边。第i次循环可以找到长度为i的最短路。

以上是关于Bellman_Ford算法的主要内容,如果未能解决你的问题,请参考以下文章

Bellman_Ford算法

Bellman_ford算法详解

bellman_ford算法_有负权边的单源最短路问题

Bellman_Ford算法求带有负边权的最短路算法

最短路(Dijkstra,Floyd,Bellman_Ford,SPFA)

bellman_ford