# _) @) D. _+ z2 T+ ^: H可行流(feasible flow) - D, [. X) S' N4 \- x . X% e/ N& v" f3 l/ X; l2 d/ B& q( [0 b
" l) M1 i' V- G. O) V/ J8 s9 v) Q- O, O+ ?
可见,当 di > 0时,表示有di 个单位的流量从网络外部流入该顶点,因此顶点i 称 为供应点(supply node)或源(source),有时也形象地称为起始点或发点等;当di < 0 时,表示有|di | 个单位的流量从该顶点流失到网络外部(或说被该顶点吸收),因此顶 点i 称为需求点(demand node)或汇(sink),有时也形象地称为终止点或收点等;当 di = 0时,顶点i 称为转运点(transshipment node)或平衡点、中间点等。此外,根据 (1)可知,对于可行网络,必有; ~8 k* |; M1 f
. @+ z; H% W2 p" x1 u9 k. E! l+ u 3 v/ C+ K/ q* A * X5 }* o+ R/ V3 u3 u也就是说,所有节点上的供需量之和为 0 是网络中存在可行流的必要条件 ; D2 p" D5 |3 \- `1 {0 M5 @8 h0 r+ P 4 b3 m1 u- S- S: B $ J( l8 C, Y; b8 Q- Z# r
; r) ?! S& H1 F: ?: K# `
1.2 最大流问题 & n: t2 z7 g# F" t& G: V考虑如下流网络 N = (V, A,U,D):节点 s 为网络中唯一的源点,t 为唯一的汇点, 而其它节点为转运点。如果网络中存在可行流 f ,此时称流 f 的流量(或流值,flow value)为 (根据(3),它自然也等于 − ),通常记为v 或v( f ) ,即 + z' f F; T; Y9 v- s 8 s# L: G: N' |& q( ~ ~5 U; @. I. u# `0 m6 h: Q( y( j( }
对这种单源单汇的网络,如果我们并不给定 和 (即流量不给定),则网络一 般记为 N = (s,t,V, A,U) 。最大流问题( maximum flow problem )就是在 N = (s,t,V, A,U) 中找到流值最大的可行流(即最大流)。我们将会看到,最大流问题 的许多算法也可以用来求解流量给定的网络中的可行流。也就是说,当我们解决了最大 流问题以后,对于在流量给定的网络中寻找可行流的问题,通常也就可以解决了。1 X/ j8 n6 w: Y+ V' C7 W: Z
5 o/ r N* f6 `) K3 P7 V3 s+ ]用线性规划描述最大流问题8 @+ n/ e# V/ c0 d" n$ H
因此,用线性规划的方法,最大流问题可以形式地描述如下:4 c4 }9 K' a! j F: c2 N' P
+ q$ j! u% L7 J( b$ g; D! c1 `4 r9 z2 a: H
, u- K6 Y; Y" X
定义】 如果一个矩阵 A 的任何子方阵的行列式的值都等于0,1或 −1,则称 A 是 全幺模的(totally unimodular TU,又译为全单位模的),或称 A 是全幺模矩阵。: A) t5 I- w: q. m; I
# g' [6 D: U J+ k4 h- X1 }4 O整流定理* @5 m& Q. L: k/ X! o+ i
【定理 7】(整流定理) 最大流问题所对应的约束矩阵是全幺模矩阵。若所有弧容量 均为正整数,则问题的最优解为整数解。 最大流问题是一个特殊的线性规划问题。我们将会看到利用图的特点,解决这个问 题的方法较之线性规划的一般方法要方便、直观得多。 , ]6 E9 c- v4 T+ ? + `0 j0 b. i1 h. W- I3 _1.3 单源和单汇运输网络 $ A* o+ R8 {2 U( m1 x: ?- _6 p多源多汇网络 转化成单源单汇网络( A/ ^* Q* d* t) U( }6 Z
实际问题往往是多源多汇网络,为了计算的规格化,可将多源多汇网络G 化成单 源单汇网络G' 。设 X 是G 的源,Y 是G 的汇,具体转化方法如下:5 t5 E& \/ A& `; N8 v4 \
. \- o! g+ c8 S+ U6 ] y1 ]
(i)在原图G 中增加两个新的顶点 x 和 y ,令为新图G' 中之单源和单汇,则G 中 所有顶点V 成为G' 之中间顶点集。: H# g7 g' Y y9 U. Z( V
& y1 C" `% X0 t! l8 k8 `1 q
(ii)用一条容量为∞的弧把 x 连接到 X 中的每个顶点。/ Q* B, R% O! ~
# S, u0 C& F$ l: ]& U0 G0 T
(iii)用一条容量为∞的弧把Y 中的每个顶点连接到 y 。 G 和G' 中的流以一个简单的方式相互对应。若 f 是G 中的流,则由 E n. S# w- ]$ C# c/ j- M
- C- w' A2 z) V5 Z* } ^ J+ d7 d2 a" U# m
4 D y" @; X- i 2 最大流和最小割关系割的容量. G) a% a, O2 @, K
, O! \+ s& v6 f2 c% d0 W( z/ {* E9 M2 }3 c+ T
4 O4 \+ ?; M* D! }" x# E/ m则在这条可增广轨上每条前向弧的流都可以增加一个量δ ,而相应的后向弧的流可减 少δ ,这样就可使得网络的流量获得增加,同时可以使每条弧的流量不超过它的容量, 而且保持为正,也不影响其它弧的流量。总之,网络中 f 可增广轨的存在是有意义的, 因为这意味着 f 不是最大流。 |5 r( i) u& b( r4 ~. K0 E/ N! \/ b6 J/ q" [
3 最大流的一种算法—标号法 + X3 O& m h9 q/ o3 B标号法是由 Ford 和 Fulkerson 在 1957 年提出的。用标号法寻求网络中最大流的基 本思想是寻找可增广轨,使网络的流量得到增加,直到最大为止。即首先给出一个初始 流,这样的流是存在的,例如零流。如果存在关于它的可增广轨,那么调整该轨上每条 弧上的流量,就可以得到新的流。对于新的流,如果仍存在可增广轨,则用同样的方法 使流的值增大,继续这个过程,直到网络中不存在关于新得到流的可增广轨为止,则该 流就是所求的最大流。 2 e0 p* D5 N5 ~ 1 n8 }) M- _ A) i9 g$ k这种方法分为以下两个过程: ; A9 N' C9 L( o$ X O b- k# o3 g+ A$ n
A.标号过程:通过标号过程寻找一条可增广轨。# }6 E( c! O% s
Z* [' {# e! L) a0 CB.增流过程:沿着可增广轨增加网络的流量。' R5 P: g" O. F
1 u) Z9 n" }/ h9 d
这两个过程的步骤分述如下。 " E! ?9 T! z [6 H7 |6 a' D/ O6 O
(A)标号过程:, Y) I& s+ M5 M9 [6 Q0 _: G$ s
. s. V. o6 ~8 h& k) O ( {; r4 u# W* [, A N% ^2 _
: y4 z7 h1 w; L# ~7 S3 f( z p (B)增流过程 ) ~0 j+ N( A! P; | 4 E$ u! E% ^# t' ]# _) b4 @" J网络最大流 x 的求解步骤 m' s! U& O6 U$ u, G
求网络 N = (s,t,V, A,U) 中的最大流 x 的算法的程序设计具体步骤如下: 5 Z. y0 @. ?% O; h; I* \# i. v/ I8 ~( p* b: a
对每个节点 j ,其标号包括两部分信息 (pred( j),maxf(j)) + {5 Y; L+ V; ~- I: }4 [; T/ t+ b. c6 O2 n- E' @
该节点在可能的增广路中的前一个节点 pred( j) ,以及沿该可能的增广路到该节点为止 可以增广的最大流量 maxf( j)。 2 ?5 J+ f* n7 `+ t) U& I1 o1 [2 I 7 v, P8 I/ J& m6 V B 5 [! x) U4 h* K/ y2 Y, C