网络流最大流算法ppt课件
合集下载
图论最大流问题.ppt
则 t S ,否则存在s到t的一条可增路,矛盾。 因此,S ,则任意 x S, y S 的边(x,y)有
若 ( x, y)是向前边,fx y cxy; ( y, x) 是后前边,
f yx 0 由定理1, max w min c(S, S )
c(S, S) c(e)
e( S ,S )
网络N中容量最小的割 (S* , S* ) 称为N的最小割。
不难证明,任何一个可行流的流量w都不会超过 任一割的容量,即
w c(S, S)
例如,图2中,若 S {s},(S, S ) {(s, v3 ),(s, v2 )} c(S, S ) 4 3 7.
二、可行流与最大流
1. 定义
在实际问题中,对于流有两个显然的要求:一是 每个弧上的流量不能超过该弧的最大通过能力(即弧 的容量);二是中间点的流量为0,源点的净流出量 和汇点的净流入量必相等。因此有定义如下。
定义2 网络N中每条边都给定一个非负实数fij满足 下列条件
(1)容量约束:0≤fij≤cij,(vi,vj)∈E, (2)守恒条件
过修改,使得整个网络的流值增大。 定义3 设f是一个可行流,P是从源点s到汇点t的一
条路,若P满足下列条件: (1)在P上的所有前向弧(vi→vj)都是非饱和弧,即
0≤fij<cij; (2)在P上的所有后向弧(vi←vj)都是非零弧,即
0<fij≤cij。则称P为(关于可行流f的)一条可增广路 径。
a
第1条可增路s,c,b,t, =2
(1,0) s (2,0)
(1,0)
第2条可增路s,a,b,c,d,t,
(2,0)
t
c (2,0) b
(1,0)
(1,0)
若 ( x, y)是向前边,fx y cxy; ( y, x) 是后前边,
f yx 0 由定理1, max w min c(S, S )
c(S, S) c(e)
e( S ,S )
网络N中容量最小的割 (S* , S* ) 称为N的最小割。
不难证明,任何一个可行流的流量w都不会超过 任一割的容量,即
w c(S, S)
例如,图2中,若 S {s},(S, S ) {(s, v3 ),(s, v2 )} c(S, S ) 4 3 7.
二、可行流与最大流
1. 定义
在实际问题中,对于流有两个显然的要求:一是 每个弧上的流量不能超过该弧的最大通过能力(即弧 的容量);二是中间点的流量为0,源点的净流出量 和汇点的净流入量必相等。因此有定义如下。
定义2 网络N中每条边都给定一个非负实数fij满足 下列条件
(1)容量约束:0≤fij≤cij,(vi,vj)∈E, (2)守恒条件
过修改,使得整个网络的流值增大。 定义3 设f是一个可行流,P是从源点s到汇点t的一
条路,若P满足下列条件: (1)在P上的所有前向弧(vi→vj)都是非饱和弧,即
0≤fij<cij; (2)在P上的所有后向弧(vi←vj)都是非零弧,即
0<fij≤cij。则称P为(关于可行流f的)一条可增广路 径。
a
第1条可增路s,c,b,t, =2
(1,0) s (2,0)
(1,0)
第2条可增路s,a,b,c,d,t,
(2,0)
t
c (2,0) b
(1,0)
(1,0)
网络的最大流.ppt
3
(4,0) 4 (5,0) (1,0) (3,0) t
(2,0) 5 (2,0)
8 6 10 7 7599
6.4.3 最大流最小割定理(福特-富克森)
• 网络的最大流等于最小割集的容量
2
hw
6.4.4 求网络最大流的标号算法
• 从任一个初始可行流出发,如 0 流 • 基本算法:找一条从 s 到 t 点的增广链(augmenting path) • 若在当前可行流下找不到增广链,则已得到最大流 • 增广链中与 s 到 t 方向一致的弧称为前向弧,反之后向弧
5
hw
P165例6 (0,∞) s
(s,8) 1
9(0)
8(0)
5(0) 2(0)
7(0) 2 9(0)
(1,8) 3 5(0)
6(0)
t (3,5)
4 10(0)
1
9(5)
8(5)
3 5(5)
(0,∞) s
5(0) 2(0) 6(0)
t (4,7)
7(0)
2 (s,7)
9(0)
4 10(0) (2,7)
第二步:增广过程 1、对增广链中的前向弧,令 f=f +q(t),q(t) 为节点 t 的标记值 2、对增广链中的后向弧,令 f=f q(t)
3、非增广链上的所有支路流量保持不变
第三步:抹除图上所有标号,回到第一步
• 以上算法是按广探法描述的,但在实际图上作业时,按深探法 进行更快捷。一次只找一条增广链,增广一次换一张图。最后 一次用广探法,以便找出最小割集
从节点 i 正向流出,可增广 q( j )=min[q( i ), cijfij] ; (3) ( j, i )是后向弧,若 fji=0,则节点 j 不标号; (4) (j, i )是后向弧,若 fji>0,则节点 j 标号为[i, q( j )],表示
(4,0) 4 (5,0) (1,0) (3,0) t
(2,0) 5 (2,0)
8 6 10 7 7599
6.4.3 最大流最小割定理(福特-富克森)
• 网络的最大流等于最小割集的容量
2
hw
6.4.4 求网络最大流的标号算法
• 从任一个初始可行流出发,如 0 流 • 基本算法:找一条从 s 到 t 点的增广链(augmenting path) • 若在当前可行流下找不到增广链,则已得到最大流 • 增广链中与 s 到 t 方向一致的弧称为前向弧,反之后向弧
5
hw
P165例6 (0,∞) s
(s,8) 1
9(0)
8(0)
5(0) 2(0)
7(0) 2 9(0)
(1,8) 3 5(0)
6(0)
t (3,5)
4 10(0)
1
9(5)
8(5)
3 5(5)
(0,∞) s
5(0) 2(0) 6(0)
t (4,7)
7(0)
2 (s,7)
9(0)
4 10(0) (2,7)
第二步:增广过程 1、对增广链中的前向弧,令 f=f +q(t),q(t) 为节点 t 的标记值 2、对增广链中的后向弧,令 f=f q(t)
3、非增广链上的所有支路流量保持不变
第三步:抹除图上所有标号,回到第一步
• 以上算法是按广探法描述的,但在实际图上作业时,按深探法 进行更快捷。一次只找一条增广链,增广一次换一张图。最后 一次用广探法,以便找出最小割集
从节点 i 正向流出,可增广 q( j )=min[q( i ), cijfij] ; (3) ( j, i )是后向弧,若 fji=0,则节点 j 不标号; (4) (j, i )是后向弧,若 fji>0,则节点 j 标号为[i, q( j )],表示
运筹学第7章最大流问题 PPT
(3)重复步骤(2),直到vt成为标号点或所有标号点 都检查过。若vt成为标号点,表明得到一条vs到vt的 增广链,转入调整过程;若所有标号点都检查过, 表明这时的可行流就是最大流,算法结束。
调整过程:在增广链上,前向边流量增加l(vt),后 向边流量减少l(vt)。
下面用实例说明具体的操作方法:例
v2 (4,3) (3,3)
vs (5,1)
(1,1) (1,1)
v1 (2,2)
v4 (5,3)
(3,0) vt (2,1)
v3
在图中给出的可行 流的基础上,求vs 到vt的最大流。
(-vv21,1)(4,3)
(3,3)
(v2,1)
v4 (5,3)
(,+∞)
vs (5,1)
(1,1) (1,1)
(v3,1)
下图中已经标示出了一个可行流,求最大流
v[2vs, 4] (4, 0)
(4, 0)
[, ∞] vs
(1, 0) (1, 0)
[v2,v44]
(3, 2)
(5, 2)
vs [v4, 3]
(2, 0)
(5, 2)
v1
[vs, 3]
(2, 2)
v5
(4, 0)
v3
[-v4, 2]
如图已经得到增广链,然后进行调整。
网络的总流量。
可行流总是存在的,例如f={0}就是一个流量为0的可 行流。
所谓最大流问题就是在容量网络中寻找流量最大的可 行流。
一个流f={fij},当fij=cij,则称f对边(vi, vj)是饱和的, 否则称f对边(vi, vj)不饱和。对于不饱和的,其间隙为 δij=cij-fij
最大流问题实际上是一个线性规划问题。
调整过程:在增广链上,前向边流量增加l(vt),后 向边流量减少l(vt)。
下面用实例说明具体的操作方法:例
v2 (4,3) (3,3)
vs (5,1)
(1,1) (1,1)
v1 (2,2)
v4 (5,3)
(3,0) vt (2,1)
v3
在图中给出的可行 流的基础上,求vs 到vt的最大流。
(-vv21,1)(4,3)
(3,3)
(v2,1)
v4 (5,3)
(,+∞)
vs (5,1)
(1,1) (1,1)
(v3,1)
下图中已经标示出了一个可行流,求最大流
v[2vs, 4] (4, 0)
(4, 0)
[, ∞] vs
(1, 0) (1, 0)
[v2,v44]
(3, 2)
(5, 2)
vs [v4, 3]
(2, 0)
(5, 2)
v1
[vs, 3]
(2, 2)
v5
(4, 0)
v3
[-v4, 2]
如图已经得到增广链,然后进行调整。
网络的总流量。
可行流总是存在的,例如f={0}就是一个流量为0的可 行流。
所谓最大流问题就是在容量网络中寻找流量最大的可 行流。
一个流f={fij},当fij=cij,则称f对边(vi, vj)是饱和的, 否则称f对边(vi, vj)不饱和。对于不饱和的,其间隙为 δij=cij-fij
最大流问题实际上是一个线性规划问题。
网络流算法课件(清华)
最小割算法的时间复杂度分析
01
最小割算法的时间复杂度主要取决于寻找最小割的步骤,即遍 历所有边的次数。
02
如果网络中边的数量为E,则最小割算法的时间复杂度为O(E),
其中E的数量与网络中节点的数量和边的数量有关。
因此,对于大规模的网络流问题,最小割算法可能会比较耗时
03 。
05
网络流算法的优化与改进
最大流算法的实现步骤
第一步
01
寻找增广路径。增广路径是从源点到汇点的一条路径,该路径
上的所有边的流量都可以增加。
第二步
02
沿着增广路径增广流量。将增广路径上的所有边的流量增加最
小割,得到新的网络流。
第三步
03
重复第一步和第二步,直到找不到增广路径为止。此时,从源
点到汇点的最大流量即为所求。
最大流算法的时间复杂度分析
最大流算法的时间复杂度主要取决于寻 找增广路径的算法。
常见的寻找增广路径的算法有FordFulkerson算法和Edmonds-Karp算法。 Ford-Fulkerson算法的时间复杂度为 O(V^2E),Edmonds-Karp算法的时间复杂 度为O(VE^2)。
其中,V表示顶点的数量,E表示边 的数量。因此,最大流算法的时间 复杂度与网络的大小成正比。
定义与特点
定义
网络流算法是一种用于解决具有特定 特性的网络流问题的算法。
特点
网络流算法通常具有高效、精确的特 点,能够处理大规模的网络流问题, 广泛应用于计算机科学、运筹学、电 子工程等领域。
网络流算法的应用场景
最大流问题
寻找在网络中从源点到汇点的最大流量。
最小割问题
确定将网络划分为两个子集的最小割点,使得两个子集之间的流量最小。
网络流算法专题ppt课件
定理4:最大流最小割定理。 最大流等于最小割,即max V(f) = min C(U, W)。
最大流算法
第1步,令x=(xij)是任意整数可行流,可能是零流,给s一个永 久标号(-, ∞)。
第2步(找增广路),如果所有标号都已经被检查,转到第4步。
找到一个标号但未检查的点i, 并做如下检查,
=8+4+4+1=17
流量算法的基本理论
定理1:对于已知的网络ຫໍສະໝຸດ 图,设任意一可行流为f, 任意一割切为(U, W),必有:V(f) ≤ C(U, W)。
定理2:可行流f是最大流的充分必要条件是:f中不 存在可改进路。
定理3:整流定理。 如果网络中所有的弧的容量是整数,则存在整数值 的最大流。
i, j, delta, x : integer; last : tline; {可改进路中的前趋} check : array[0 .. maxn] of boolean; {检查数组} begin repeat fillchar(last, sizeof(last), 0); fillchar(check, sizeof(check), false); last[1] := maxint; repeat
Capacity=2 Flow=2
Capacity=6 Flow=2
图
剩 余
3 2
2
4 2
剩余图中,每条边都可以沿其方向增广
剩余图中,从源点到汇点的每一条路径都对应一条 增广路
割切
G = (V, E, C)是已知的网络流图,设U是V的一个子集,W = V\U,满足S ∈ U,T∈W。即U、W把V分成两个不相交 的集合,且源点和汇点分属不同的集合。
可增广路
最大流算法
第1步,令x=(xij)是任意整数可行流,可能是零流,给s一个永 久标号(-, ∞)。
第2步(找增广路),如果所有标号都已经被检查,转到第4步。
找到一个标号但未检查的点i, 并做如下检查,
=8+4+4+1=17
流量算法的基本理论
定理1:对于已知的网络ຫໍສະໝຸດ 图,设任意一可行流为f, 任意一割切为(U, W),必有:V(f) ≤ C(U, W)。
定理2:可行流f是最大流的充分必要条件是:f中不 存在可改进路。
定理3:整流定理。 如果网络中所有的弧的容量是整数,则存在整数值 的最大流。
i, j, delta, x : integer; last : tline; {可改进路中的前趋} check : array[0 .. maxn] of boolean; {检查数组} begin repeat fillchar(last, sizeof(last), 0); fillchar(check, sizeof(check), false); last[1] := maxint; repeat
Capacity=2 Flow=2
Capacity=6 Flow=2
图
剩 余
3 2
2
4 2
剩余图中,每条边都可以沿其方向增广
剩余图中,从源点到汇点的每一条路径都对应一条 增广路
割切
G = (V, E, C)是已知的网络流图,设U是V的一个子集,W = V\U,满足S ∈ U,T∈W。即U、W把V分成两个不相交 的集合,且源点和汇点分属不同的集合。
可增广路
《网络最大流问题》PPT课件
《网络最大流问题》PPT课件
本课件仅供大家学习学习 学习完毕请自觉删除
谢谢 本课件仅供大家学习学习
学习完毕请自觉删除 谢谢
第六章 图与网络分析
第一节 图的基本知识 第二节 树 第三节 最短路问题 第四节 网络最大流问题 第五节 最小费用最大流问题
第四节 网络最大流问题
图10-23是联结某产品产地v1和销地v6的交通网,每一
给vt标号为(v4, l(vt)),这里 l(vt)=min[l(v4), (c4t- f4t)]=min[1, 2]=1
因vt有了标号,故转入调整过程。
(3,3) (0,+∞) vs
(5,1)
v2 (-v1,1) (4,3) v4 (v2,1) (5,3)
(1,1) (1,1) (3,0)
vt (v4,1)
(3,3)
(5,3)
(0,+∞) vs (5,1)
(1,1) (1,1)
(3,0) vt (2,1)
v1 (vs,4) (2,2) v3
(4) 检查v2。
在弧(v2,v4)上,f21=3, c24=4,f24< c24,则给
v4标号(v2, l(v4)) 。
l(v4) = min[l(v2), (c24- f24)]=min[1, 1]=1 在 弧 (v3 , v2) 上 , f32=1>0 , 给 v3 标 号 : (-v2,
便不存在路。所以,截集是从vs到的vt必经之路。
定义5 给一截集(V1, V)__,1 把截集(V1, )中V__1 所有弧的 容量之和称为这个截集的容量(简称为截量),记为
c(V1, ),即V__1
cV1,V1
cij
(vi,vj)(V 1,V1)
本课件仅供大家学习学习 学习完毕请自觉删除
谢谢 本课件仅供大家学习学习
学习完毕请自觉删除 谢谢
第六章 图与网络分析
第一节 图的基本知识 第二节 树 第三节 最短路问题 第四节 网络最大流问题 第五节 最小费用最大流问题
第四节 网络最大流问题
图10-23是联结某产品产地v1和销地v6的交通网,每一
给vt标号为(v4, l(vt)),这里 l(vt)=min[l(v4), (c4t- f4t)]=min[1, 2]=1
因vt有了标号,故转入调整过程。
(3,3) (0,+∞) vs
(5,1)
v2 (-v1,1) (4,3) v4 (v2,1) (5,3)
(1,1) (1,1) (3,0)
vt (v4,1)
(3,3)
(5,3)
(0,+∞) vs (5,1)
(1,1) (1,1)
(3,0) vt (2,1)
v1 (vs,4) (2,2) v3
(4) 检查v2。
在弧(v2,v4)上,f21=3, c24=4,f24< c24,则给
v4标号(v2, l(v4)) 。
l(v4) = min[l(v2), (c24- f24)]=min[1, 1]=1 在 弧 (v3 , v2) 上 , f32=1>0 , 给 v3 标 号 : (-v2,
便不存在路。所以,截集是从vs到的vt必经之路。
定义5 给一截集(V1, V)__,1 把截集(V1, )中V__1 所有弧的 容量之和称为这个截集的容量(简称为截量),记为
c(V1, ),即V__1
cV1,V1
cij
(vi,vj)(V 1,V1)
最大流PPT课件
未标号,则给v j
(i,
一个标号
(
j)
min{x ji ,
(i)})
.
2.3 如果t已被标号,转3,否则转2.1.
.
12
Ford-Fulkerson算法
3. 根据得到的增广路上各顶点标号来增加流 量,抹去s外所有顶点标号,转2. 4. 此时当前流是最大流,且把所有标号点集 记为 S,则(S, S) 就是最小割.
0,f,vvi i
s s,
t
v jV
v jV
f,vi t
• 目标: max f xs*j x*jt
j
j
.
3
• 最大流问题的线性规划模型:
max f
s.t. xij f , vi t
vj
vj
xij x ji 0, vi s,t
.
5
3,1 s
2,2
3,2 s
2,2
v1 2,1 1,0
v3 2,2 v1 2,2
1,0 v3 2,2
v2 3,2
1,1
t
2,1 v4 v2
3,2
1,0
t
2,2 v4
.
6
• 一个弧割 (S, S) 若满足s S,t S ,则称为(s,t) 割,其
容量定义为C(S, S) cij . viS v jS
• 标号过程中,增加先标号先检查的原则.
.
16
• 整数假设 • 实数包含有理数和无理数. • 有理数就是分数,扩大若干倍可以变成整
数. • 而对于无理数,Ford和Fulkerson[1962]证
明了算法会收敛到一个不是最大流的流值. • 现实中流量是不会出现无理数的.
第六章、网络流
如果顶点关联的边为 饱和边,则无需标号
§4 2F最大流最小切割标号算法2
什么是饱和边? 向前边:fij=cij时 后退边: fij=0时 称为饱和边;
§4 2F标号算法描述
2F算法描述: (1)初始化f(e)=0,e∈E; //初始化 (2)给源点s标号(-,∞),其它顶点均未标号; (3)依次选一个未标号的顶点,根据其方向进行标号,若当前标号的顶点为t,转(4),否则转入(6); (4)选择一条标号过的增流路径进行增流; (5)转(2) (6)这时得到的f就是最大容许流。
S={s,b,c,d}, ={a,t}
S
C(S, )=csa+cba+cbt+cdt=4+3+2+4=13
S
S
å
Î
Î
S
j
S
i
ij
c
(S, )={(s,a),(b,a),(b,t),(d,t)}
S
§2 割切-定理6.1
网络容许流量和切割容量之间存在下述关系: 定理6.1:网络流的最大流量小于等于的任意的割切容量,即:max w≤ C(S, )。
§1 网络流图问题和最大流-例
下图所示就是一个网络流图:
例
s
t
a
b
c
d
4
4
3
3
2
2
2
4
1
3
2
源点
汇点
容量
中转站
§1 网络流图问题和最大流-2
对于网络流图G,每条边都给定一个非负数fij,这组数满足下面条件,称为网络的容许流(flow),记作f。 (1)0≤fij≤ c(i,j); (2)除源点s和汇点t,其余顶点vi恒有: ∑fij=∑ fki 即每个点流入和流出量相同; (3)对于源点s和汇点t有: ∑fsi=∑ fjt=w w称为网络流的流量。
§4 2F最大流最小切割标号算法2
什么是饱和边? 向前边:fij=cij时 后退边: fij=0时 称为饱和边;
§4 2F标号算法描述
2F算法描述: (1)初始化f(e)=0,e∈E; //初始化 (2)给源点s标号(-,∞),其它顶点均未标号; (3)依次选一个未标号的顶点,根据其方向进行标号,若当前标号的顶点为t,转(4),否则转入(6); (4)选择一条标号过的增流路径进行增流; (5)转(2) (6)这时得到的f就是最大容许流。
S={s,b,c,d}, ={a,t}
S
C(S, )=csa+cba+cbt+cdt=4+3+2+4=13
S
S
å
Î
Î
S
j
S
i
ij
c
(S, )={(s,a),(b,a),(b,t),(d,t)}
S
§2 割切-定理6.1
网络容许流量和切割容量之间存在下述关系: 定理6.1:网络流的最大流量小于等于的任意的割切容量,即:max w≤ C(S, )。
§1 网络流图问题和最大流-例
下图所示就是一个网络流图:
例
s
t
a
b
c
d
4
4
3
3
2
2
2
4
1
3
2
源点
汇点
容量
中转站
§1 网络流图问题和最大流-2
对于网络流图G,每条边都给定一个非负数fij,这组数满足下面条件,称为网络的容许流(flow),记作f。 (1)0≤fij≤ c(i,j); (2)除源点s和汇点t,其余顶点vi恒有: ∑fij=∑ fki 即每个点流入和流出量相同; (3)对于源点s和汇点t有: ∑fsi=∑ fjt=w w称为网络流的流量。
最大流算法及其应用 PPT课件
【数据规模和约定】 80%的数据中:N≤200,M≤1 000。 100%的数据中:N≤5 000,M≤50 000,
0≤Ci≤100,0≤Pi≤100。
分析
看到了“最大”这个字眼,很多人便以为 此题与最小割没有关系,但实际上不是。 由于:
净获利 = 获益之和 - 投入成本之和
= 所有用户群的获益 - (损失用户
分析
实际上我们可以将二分图的最大匹配问题 转换为最大流问题。增加源和汇,将源连 到每个左边的点,将每个右边的点连到汇, 并把原来的边改为有向的,从左边的点指 向右边的点,最后把图中所有弧的容量赋 为1,这个流网络的最大流即为原二分图的 最大匹配。
图3 新建的流网络(图中弧的容量均为1)
s
t
分析(续)
零流,即对于(u,v)∈E时,f(u,v)=0。然后构建残
留网络,寻找增广路径增广,再修改残留网络, 重复此过程,直到无法找到增广路径。此方法 (之所以不是算法,是因为实现方法很多)称为 Ford-Fulkerson方法。
Ford-Fulkerson方法的伪代码
FORD-FULKERSON-METHORD (G, s, t) 1 initialize flow f to 0 2 while there exists an augmenting path p 3 do augment flow f along p 4 return f
算法基本架构
Procedure Shortest_Augmenting_Path; Var …… Begin 预处理流为零流,建立残留网络 计算距离函数d(i) //实际上一开始没有必要用BFS计算,清零就行了 i:=s;
while d(s)<n do
begin
0≤Ci≤100,0≤Pi≤100。
分析
看到了“最大”这个字眼,很多人便以为 此题与最小割没有关系,但实际上不是。 由于:
净获利 = 获益之和 - 投入成本之和
= 所有用户群的获益 - (损失用户
分析
实际上我们可以将二分图的最大匹配问题 转换为最大流问题。增加源和汇,将源连 到每个左边的点,将每个右边的点连到汇, 并把原来的边改为有向的,从左边的点指 向右边的点,最后把图中所有弧的容量赋 为1,这个流网络的最大流即为原二分图的 最大匹配。
图3 新建的流网络(图中弧的容量均为1)
s
t
分析(续)
零流,即对于(u,v)∈E时,f(u,v)=0。然后构建残
留网络,寻找增广路径增广,再修改残留网络, 重复此过程,直到无法找到增广路径。此方法 (之所以不是算法,是因为实现方法很多)称为 Ford-Fulkerson方法。
Ford-Fulkerson方法的伪代码
FORD-FULKERSON-METHORD (G, s, t) 1 initialize flow f to 0 2 while there exists an augmenting path p 3 do augment flow f along p 4 return f
算法基本架构
Procedure Shortest_Augmenting_Path; Var …… Begin 预处理流为零流,建立残留网络 计算距离函数d(i) //实际上一开始没有必要用BFS计算,清零就行了 i:=s;
while d(s)<n do
begin
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
– 注:此处的s-t流不单指图中特定的s-t路
• s-t流的值:源点s的流出量;
– 2、s-t割:即点集S指向点集T(此处T=V(G)\X)的边 集,其中s∈S且t∈T
• 割的容量:各边容量之和 • 最小s-t割:在G中关于u具有最小容量的s-t割
ppt课件
8
Maximum Flow-Minimum Cut Theorem
– 注:此处的路径P不一定是可扩路
ppt课件
4
Ford–Fulkerson algorithm
• 输入:网络(G、u、s、t)及各边容量
• 输出:一条最大值的s-t流f
• 算法描述:
– 1、初始时令所有边的流量f=0;
– 2、求出剩余图(residual graph) ,并在 中找一条可扩路(the augmenting path)P。若 无可扩路,则终止;
Network Flow
Presented by
ppt课件
1
Network Flow
• 基本性质:
– 对于网络(G,u,s,t)
• 1、容量限制(Capacity Constraints):F(x,y) <= C(x,y) • 2、流量守恒(Flow Conservation):ΣF(v,x) = ΣF(x,u) • 3、斜对称性(Skew Symmetry): F(x,y) = -F(y,x)
• 设F为最大流,K为最小割,则value(f) <= value(F) <= cap(K) <= cap(K')
• 故f即为最大流,K'即为最小割
ppt课件
11
• Ford–Fulkerson算法的劣势:
ppt课件
12
Edmonds–Karp algorithm
-最大流问题的第一个多项式时间算法
• 3、设F为网络的最大流,K为最小割,
– 则value(F) <= cap(K) – s∈S,t∈T;其中,令S = {v∈V(G)|从源s到v有f可扩路}∪{s}; – 则t∉S(否则存在s-t可扩路,可得到更大的流),从而K' = (S,T)是网络
中的一个割,故cap(K') >= cap(K); – 又可证(S,T)中每条边的f都饱和,而(T,S)中每条边的f都为零,故
value(F) = cap(K') >= cap(K) – 综上,value(F) = cap(K)
ppt课件
10
Theorem
• 网络N(G,u,s,t)中的可行流f是N的最大流当 且仅当N中不存在f可扩路
– 必要性:若有可扩路P,沿P使f扩大即可
– 充分性:设网络中不存在可扩路
• 令S = {v∈V(G)|从源s到v有f可扩路}∪{s},则与最 大流最小割定理同样可证K' = (S,T)是网络中的一个 割,且value(f) = cap(K')
– 与Ford–Fulkerson算法相比,改进之处在于第二步中P路 径的选择,与其任选,不如选最短(边数最少)
• 算法步骤:
– 1、令所有边的流量f=0; – 2、在 中找条最短可扩路P,若无,则止; – 3、算出P路中各边剩余容量的最小值r,并沿P
使f扩充r,转2;
• 复杂度:
• Edmonds–Karp可在O(m*m*n)内得解
ppt课件
3
Ford–Fulkerson algorithm
• Definition:
– 3、一条f可扩路(the augmenting path):剩余 图中的一条s-t路
– 4、给定一个流f及剩余图中的一条路(或圈)P, 沿P使f扩充r:对每一个e∈E(P)
• 若e∈E(G),则令f(e)增加r; • 设e0∈E(G),若e为e0的反向边,则令f(e0)减小r
15
Dinic's algorithm
• 算法步骤:
– 1、令所有边的流量f=0; – 2、构造剩余图的分层图(level graph) – 3、在分层图中求一个阻塞的s-t流(the
blocking flow)f',若f'=0,则止 – 4、用f'对f扩充,转2
• 复杂度:在一定基础上可达O(mn log n), 其中,n为点数、m为边数(详见课本153)
– 3、算出P路中各边剩余容量的最小值r,并沿P 使f扩充r,转2;
ppt课件
5
ppt课件
6
ppt课件
7
Maximum Flow-Minimum Cut
Theorem
• Definition:
– 1、s-t流:指满足如下条件的流:
• a、源点流出量>0 • b、除s、t点外,图G中的所有点流量守恒
• Definition:
ppt课件
9Байду номын сангаас
Maximum Flow-Minimum Cut
Theorem
• 任一个网络(G,u,s,t)中,最大流的流量等于最小 割的容量
– 证明:
• 1、任意一个流小于等于任意一个割(S,T),即value(F) <= cap(S,T)
• 2、s∈S,t∈T当且仅当(S,T)中每条边的f都饱和,而(T,S)中每 条边的f都为零时上式取等
ppt课件
16
• Dinic算法的Example
• 讨论的前提:
– G为简单有向图 – 网络(G,u,s,t)中所有容量均为整数
• 最大流(max-flow)问题,就是求在满足网络流性质 的情况下,源点 s 到汇点 t 的最大流量。
ppt课件
2
Ford–Fulkerson algorithm
• Definition:
– 1、剩余图(residual graph): – 2、剩余容量(residual capacity):
– Edmonds–Karp算法中无论边容量多大,最多增流m*n/2 次(m为边数,n为点数)
– 每次增流用BFS最大为O(m)
ppt课件
13
Dinic's algorithm
• Definition:
– 分层图(level graph)
• 首先,分层图是基于剩余图的
• 其次,分层图会对所有顶点标号(与s的距离)
• 最后,分层图中只存在这样的剩余边(u,v): dist(v)=dist(u)+1,不符合这一规律的边全部删去
ppt课件
14
Dinic's algorithm
• Definition:
– 阻塞流(blocking flow):
• 网络(G,u,s,t)对应的分层图中所有可扩路的并,即 为阻塞流
ppt课件
• s-t流的值:源点s的流出量;
– 2、s-t割:即点集S指向点集T(此处T=V(G)\X)的边 集,其中s∈S且t∈T
• 割的容量:各边容量之和 • 最小s-t割:在G中关于u具有最小容量的s-t割
ppt课件
8
Maximum Flow-Minimum Cut Theorem
– 注:此处的路径P不一定是可扩路
ppt课件
4
Ford–Fulkerson algorithm
• 输入:网络(G、u、s、t)及各边容量
• 输出:一条最大值的s-t流f
• 算法描述:
– 1、初始时令所有边的流量f=0;
– 2、求出剩余图(residual graph) ,并在 中找一条可扩路(the augmenting path)P。若 无可扩路,则终止;
Network Flow
Presented by
ppt课件
1
Network Flow
• 基本性质:
– 对于网络(G,u,s,t)
• 1、容量限制(Capacity Constraints):F(x,y) <= C(x,y) • 2、流量守恒(Flow Conservation):ΣF(v,x) = ΣF(x,u) • 3、斜对称性(Skew Symmetry): F(x,y) = -F(y,x)
• 设F为最大流,K为最小割,则value(f) <= value(F) <= cap(K) <= cap(K')
• 故f即为最大流,K'即为最小割
ppt课件
11
• Ford–Fulkerson算法的劣势:
ppt课件
12
Edmonds–Karp algorithm
-最大流问题的第一个多项式时间算法
• 3、设F为网络的最大流,K为最小割,
– 则value(F) <= cap(K) – s∈S,t∈T;其中,令S = {v∈V(G)|从源s到v有f可扩路}∪{s}; – 则t∉S(否则存在s-t可扩路,可得到更大的流),从而K' = (S,T)是网络
中的一个割,故cap(K') >= cap(K); – 又可证(S,T)中每条边的f都饱和,而(T,S)中每条边的f都为零,故
value(F) = cap(K') >= cap(K) – 综上,value(F) = cap(K)
ppt课件
10
Theorem
• 网络N(G,u,s,t)中的可行流f是N的最大流当 且仅当N中不存在f可扩路
– 必要性:若有可扩路P,沿P使f扩大即可
– 充分性:设网络中不存在可扩路
• 令S = {v∈V(G)|从源s到v有f可扩路}∪{s},则与最 大流最小割定理同样可证K' = (S,T)是网络中的一个 割,且value(f) = cap(K')
– 与Ford–Fulkerson算法相比,改进之处在于第二步中P路 径的选择,与其任选,不如选最短(边数最少)
• 算法步骤:
– 1、令所有边的流量f=0; – 2、在 中找条最短可扩路P,若无,则止; – 3、算出P路中各边剩余容量的最小值r,并沿P
使f扩充r,转2;
• 复杂度:
• Edmonds–Karp可在O(m*m*n)内得解
ppt课件
3
Ford–Fulkerson algorithm
• Definition:
– 3、一条f可扩路(the augmenting path):剩余 图中的一条s-t路
– 4、给定一个流f及剩余图中的一条路(或圈)P, 沿P使f扩充r:对每一个e∈E(P)
• 若e∈E(G),则令f(e)增加r; • 设e0∈E(G),若e为e0的反向边,则令f(e0)减小r
15
Dinic's algorithm
• 算法步骤:
– 1、令所有边的流量f=0; – 2、构造剩余图的分层图(level graph) – 3、在分层图中求一个阻塞的s-t流(the
blocking flow)f',若f'=0,则止 – 4、用f'对f扩充,转2
• 复杂度:在一定基础上可达O(mn log n), 其中,n为点数、m为边数(详见课本153)
– 3、算出P路中各边剩余容量的最小值r,并沿P 使f扩充r,转2;
ppt课件
5
ppt课件
6
ppt课件
7
Maximum Flow-Minimum Cut
Theorem
• Definition:
– 1、s-t流:指满足如下条件的流:
• a、源点流出量>0 • b、除s、t点外,图G中的所有点流量守恒
• Definition:
ppt课件
9Байду номын сангаас
Maximum Flow-Minimum Cut
Theorem
• 任一个网络(G,u,s,t)中,最大流的流量等于最小 割的容量
– 证明:
• 1、任意一个流小于等于任意一个割(S,T),即value(F) <= cap(S,T)
• 2、s∈S,t∈T当且仅当(S,T)中每条边的f都饱和,而(T,S)中每 条边的f都为零时上式取等
ppt课件
16
• Dinic算法的Example
• 讨论的前提:
– G为简单有向图 – 网络(G,u,s,t)中所有容量均为整数
• 最大流(max-flow)问题,就是求在满足网络流性质 的情况下,源点 s 到汇点 t 的最大流量。
ppt课件
2
Ford–Fulkerson algorithm
• Definition:
– 1、剩余图(residual graph): – 2、剩余容量(residual capacity):
– Edmonds–Karp算法中无论边容量多大,最多增流m*n/2 次(m为边数,n为点数)
– 每次增流用BFS最大为O(m)
ppt课件
13
Dinic's algorithm
• Definition:
– 分层图(level graph)
• 首先,分层图是基于剩余图的
• 其次,分层图会对所有顶点标号(与s的距离)
• 最后,分层图中只存在这样的剩余边(u,v): dist(v)=dist(u)+1,不符合这一规律的边全部删去
ppt课件
14
Dinic's algorithm
• Definition:
– 阻塞流(blocking flow):
• 网络(G,u,s,t)对应的分层图中所有可扩路的并,即 为阻塞流
ppt课件