1 最大流问题的数学描述3 r" T; M# d$ @, q- H
1.1 网络中的流 定义 * z. @$ ^/ D+ N1 w$ n在以V 为节点集, A 为弧集的有向图G = (V, A) 上定义如下的权函数:1 ]0 I6 }6 e( x: a! W4 _3 Z
/ F! z) B5 j7 H: y(i) L : A → R 为孤上的权函数,弧 (i, j)∈ A 对应的权 L(i, j) 记为 ,称为孤 (i, j) 的容量下界(lower bound); 6 ^( u$ d" G$ y; O $ }' D& [% X9 A$ w9 @& U+ b(ii)U : A → R 为弧上的权函数,弧(i, j)∈ A对应的权U(i, j) 记为 ,称为孤 (i, j) 的容量上界或容量(capacity); - ]( W$ j. T1 `* H4 N- ^! v2 h! w: w) f; B
(iii) D :V → R 为顶点上的权函数,节点i ∈V 对应的权 D(i) 记为 ,称为顶 点i 的供需量(supply/demand);! r" m' D# S+ K6 V2 W
) w: W- R9 p, A3 x/ a: Z
此时所构成的网络称为流网络,可以记为 N = (V, A, L,U,D) 。 由于我们只讨论V, A 为有限集合的情况,所以对于弧上的权函数 L,U 和顶点上的 权函数 D ,可以直接用所有孤上对应的权和顶点上的权组成的有限维向量表示,因此 L,U, D 有时直接称为权向量,或简称权。由于给定有向图G = (V, A) 后,我们总是可 以在它的弧集合和顶点集合上定义各种权函数,所以流网络一般也直接简称为网络。 - b% ~( e4 ?8 x2 E0 X. e9 X! t- ^4 Q$ g 5 E0 a* w* U6 B/ C在流网络中,弧(i, j) 的容量下界 和容量上界表示的物理意义分别是:通过该 弧发送某种“物质”时,必须发送的最小数量为 ,而发送的最大数量为 。顶点i ∈V 对应的供需量则表示该顶点从网络外部获得的“物质”数量( > 0时),或从该顶 点发送到网络外部的“物质”数量(< 0 时)。下面我们给出严格定义。$ ?& U0 o' e) X! ~, J5 m! @
1 n! M X+ d' x7 n/ V9 _可行流(feasible flow)- |1 v" k* f! l
9 t( y/ m7 ~& x- h. ?& u& g4 q3 }( C! T% e5 e1 Q
; [# b7 s/ a/ G$ A
0 c& I+ Y5 d/ K
可见,当 di > 0时,表示有di 个单位的流量从网络外部流入该顶点,因此顶点i 称 为供应点(supply node)或源(source),有时也形象地称为起始点或发点等;当di < 0 时,表示有|di | 个单位的流量从该顶点流失到网络外部(或说被该顶点吸收),因此顶 点i 称为需求点(demand node)或汇(sink),有时也形象地称为终止点或收点等;当 di = 0时,顶点i 称为转运点(transshipment node)或平衡点、中间点等。此外,根据 (1)可知,对于可行网络,必有 % g5 R5 J _4 ?' ^* I- G+ w) d' a4 V/ ?& n D) c & } C( r+ ?# m5 Z& ~ 6 ]3 A$ R1 y( B0 a. E: I- H也就是说,所有节点上的供需量之和为 0 是网络中存在可行流的必要条件 9 m, W% a; ^' s( ~. @ E. w ) x- i) ?* ^- T4 `/ S# o8 u, z3 D: ^. W) z1 P. w2 n0 ~$ W6 D* V + X9 y8 Y, W0 e3 B
% P) c& z- G9 ~* p
1.2 最大流问题4 O/ _. G- T1 M6 g7 G f% L
考虑如下流网络 N = (V, A,U,D):节点 s 为网络中唯一的源点,t 为唯一的汇点, 而其它节点为转运点。如果网络中存在可行流 f ,此时称流 f 的流量(或流值,flow value)为 (根据(3),它自然也等于 − ),通常记为v 或v( f ) ,即9 q" m6 d' T+ K. ^
3 ?4 F* ^2 X5 [" F$ X+ p' X1 @) w y3 B0 M; _' ^
对这种单源单汇的网络,如果我们并不给定 和 (即流量不给定),则网络一 般记为 N = (s,t,V, A,U) 。最大流问题( maximum flow problem )就是在 N = (s,t,V, A,U) 中找到流值最大的可行流(即最大流)。我们将会看到,最大流问题 的许多算法也可以用来求解流量给定的网络中的可行流。也就是说,当我们解决了最大 流问题以后,对于在流量给定的网络中寻找可行流的问题,通常也就可以解决了。 " V2 N! n8 Z) P5 P8 Z * B# x1 Q+ [( B2 U# o/ {用线性规划描述最大流问题& b5 N7 i4 ^7 V" a) t: y
因此,用线性规划的方法,最大流问题可以形式地描述如下:; \' t/ ~4 P% G- r6 I/ b
% x$ d! d. {5 d3 I9 J2 G% u0 K. d& ` ; Z# o% _3 m& z
6 h# x3 G8 @$ J9 Z+ _
定义】 如果一个矩阵 A 的任何子方阵的行列式的值都等于0,1或 −1,则称 A 是 全幺模的(totally unimodular TU,又译为全单位模的),或称 A 是全幺模矩阵。 & N9 [" v' W2 [6 p3 U9 e( z' C; _
整流定理 5 j! ?" |) l' ]& [【定理 7】(整流定理) 最大流问题所对应的约束矩阵是全幺模矩阵。若所有弧容量 均为正整数,则问题的最优解为整数解。 最大流问题是一个特殊的线性规划问题。我们将会看到利用图的特点,解决这个问 题的方法较之线性规划的一般方法要方便、直观得多。 ; X6 e2 @; P$ C0 C ' A6 S, G3 j8 H) A1.3 单源和单汇运输网络. _' q: p. z A/ Y2 z( X( o
多源多汇网络 转化成单源单汇网络2 e: G- o$ H2 k& ~7 d& X% D
实际问题往往是多源多汇网络,为了计算的规格化,可将多源多汇网络G 化成单 源单汇网络G' 。设 X 是G 的源,Y 是G 的汇,具体转化方法如下: & y2 ^4 X4 O: F5 h; x' ^% c! E p: M' j- C, v( m5 r# Q(i)在原图G 中增加两个新的顶点 x 和 y ,令为新图G' 中之单源和单汇,则G 中 所有顶点V 成为G' 之中间顶点集。 6 {: Y' @* G9 }, [ G # v6 e. V3 ]8 \5 z(ii)用一条容量为∞的弧把 x 连接到 X 中的每个顶点。; J# t& c9 l/ ?# a+ q" \. W& k
% ^0 J H: _' J(iii)用一条容量为∞的弧把Y 中的每个顶点连接到 y 。 G 和G' 中的流以一个简单的方式相互对应。若 f 是G 中的流,则由 5 C7 M) _3 u/ D1 l; c- n3 C$ N' T & M0 w. |; `( Q% F, ~6 Z" X' C4 z) F' [! e2 G" k! g
# T; T- P/ X! q, M7 C2 最大流和最小割关系割的容量9 F8 G; G4 N) x2 D# ~! N
6 y4 v, z" Y0 b6 T5 h2 M % I& L+ s3 F6 z5 G$ x! Y
/ H0 V: ~5 H4 g) i) n
则在这条可增广轨上每条前向弧的流都可以增加一个量δ ,而相应的后向弧的流可减 少δ ,这样就可使得网络的流量获得增加,同时可以使每条弧的流量不超过它的容量, 而且保持为正,也不影响其它弧的流量。总之,网络中 f 可增广轨的存在是有意义的, 因为这意味着 f 不是最大流。0 p9 ], Z7 h; b7 {, ]: Z