以经过调整,得到一个新的可行流,其流量比原来的可
行流要大,重复这个过程,直到不存在关于该流的增广 链时就得到了最大流。
寻求最大流的思路:利用定理1中对V1*定义,根据vt是 否属于V1*来判断D中有无关于f的增广链。 实际计算时,可以用给顶点标号的方法来确定属 于V1*的点。
在标号过程中,有标号的顶点表示是V1*中的点,
l(v3) = min[l(v2), f32]=min[1, 1]=1
v2 (-v1,1) (4,3) (3,3) (0,+∞) vs (5,1) v1 (vs,4) (2,2) v4 (v2,1) (5,3) (3,0) (2,1) v3 (-v2,1) vt
(1,1)
(1,1)
(5) 在v3, v4中任选一个进行检查。
v4 (v2,1) (5,3)
(3,0) (2,1) v3 (-v2,1) vt (v4,1)
(二) 调整过程 (1) 按点的第一个标号找到一条增广链。
v2 (-v1,1) (4,3) (3,3) v4 (v2,1) (5,3)
(0,+∞) vs
(5,1)
(1,1)
(1,1)
(3,0)
(2,1)
vt (v4,1)
(2)未标号点。
标号过程: (1) 给发点 vs 标上 (0 , +∞) ;这时 vs 是标号而未检查
的点,其余都是未标号点。
(2) 取一个标号而未检查的点 vi,对于vi的所有未给 标号的相邻点vj按下列规则处理: (a)若在弧(vi,vj) 上,fij<cij,则给vj标号(vi,l(vj))。这 里l(vj)=min[l(vi), cij-fij]。这时点vj成为标号而未检查的点。 (b) 若在弧 (vj,vi)上, fji>0 ,则给 vj 标号 (-vi , l(vj)),这 里l(vj)=min[(l(vi),fij]。这时点vj成为标号而未检查的点。 这样,vj成为标号而已检查过的点。