松弛操作是指对于每个顶点v∈V,都设置一个属性d[v],用来描述从源点s到v的
最短路径上权值的上界,称为最短路径估计(shortest-path estimate)。
π[v]代表S到v的当前
最短路径中v点之前的一个点的编号,我们用下面的Θ(V)时间的过程来对最短路径估计和前趋进行初始化。
在松弛一条边(u,v)的过程中,要测试是否可以通过u,对迄今找到的v的
最短路径进行改进;如果可以改进的话,则更新d[v]和π[v]。一次松弛操作可以减小
最短路径估计的值d[v],并更新v的前趋域π[v](S到v的当前最短路径中v点之前的一个点的编号)。下面的
伪代码对边(u,v)进行了一步松弛操作。
每个
单源最短路径算法中都会调用INITIALIZE-SINGLE-SOURCE,然后重复对边进行松弛的过程。另外,松弛是改变
最短路径和前趋的唯一方式。各个
单源最短路径算法间区别在于对每条边进行松弛操作的次数,以及对边执行松弛操作的次序有所不同。在
Dijkstra算法以及关于有向无回路图的
最短路径算法中,对每条边执行一次松弛操作。在
Bellman-Ford算法中,每条边要执行多次松弛操作。