- 在线时间
- 791 小时
- 最后登录
- 2022-11-28
- 注册时间
- 2017-6-12
- 听众数
- 15
- 收听数
- 0
- 能力
- 120 分
- 体力
- 36352 点
- 威望
- 11 点
- 阅读权限
- 255
- 积分
- 13866
- 相册
- 0
- 日志
- 0
- 记录
- 1
- 帖子
- 616
- 主题
- 542
- 精华
- 12
- 分享
- 0
- 好友
- 225
TA的每日心情 | 开心 2020-11-14 17:15 |
|---|
签到天数: 74 天 [LV.6]常住居民II
 群组: 2019美赛冲刺课程 群组: 站长地区赛培训 群组: 2019考研数学 桃子老师 群组: 2018教师培训(呼伦贝 群组: 2019考研数学 站长系列 |
1 最大流问题的数学描述8 x) z3 k1 l- x2 p9 i3 L" \
1.1 网络中的流 定义5 E: v: M ]9 {% u/ J
在以V 为节点集, A 为弧集的有向图G = (V, A) 上定义如下的权函数:$ e, ?$ m1 N/ X/ z4 G- E9 V6 A
5 S8 r; m$ }& {. j( H9 m(i) L : A → R 为孤上的权函数,弧 (i, j)∈ A 对应的权 L(i, j) 记为 ,称为孤 (i, j) 的容量下界(lower bound);$ X/ ?+ S9 N+ E, B8 d# w
! \) E) s c" V. N7 |(ii)U : A → R 为弧上的权函数,弧(i, j)∈ A对应的权U(i, j) 记为 ,称为孤 (i, j) 的容量上界或容量(capacity);
. V6 N# \3 }* {* ?: |# n& X
( ]# H! {% U9 t' C(iii) D :V → R 为顶点上的权函数,节点i ∈V 对应的权 D(i) 记为 ,称为顶 点i 的供需量(supply/demand);
0 \; [( k3 \8 H' e
2 P9 u" L r/ ?4 z) P此时所构成的网络称为流网络,可以记为 N = (V, A, L,U,D) 。 由于我们只讨论V, A 为有限集合的情况,所以对于弧上的权函数 L,U 和顶点上的 权函数 D ,可以直接用所有孤上对应的权和顶点上的权组成的有限维向量表示,因此 L,U, D 有时直接称为权向量,或简称权。由于给定有向图G = (V, A) 后,我们总是可 以在它的弧集合和顶点集合上定义各种权函数,所以流网络一般也直接简称为网络。
! u' T0 H0 p) q ]3 M0 n! f
' N+ Z, t8 L( R9 q在流网络中,弧(i, j) 的容量下界 和容量上界表示的物理意义分别是:通过该 弧发送某种“物质”时,必须发送的最小数量为 ,而发送的最大数量为 。顶点i ∈V 对应的供需量则表示该顶点从网络外部获得的“物质”数量( > 0时),或从该顶 点发送到网络外部的“物质”数量(< 0 时)。下面我们给出严格定义。
/ E1 w/ x2 p/ X% }2 L' i1 D; j% L; } k$ F2 \; e/ B2 R2 y
可行流(feasible flow)
9 i5 G) k2 [/ g a3 x0 W6 r3 ~: f
1 t4 q, Z, [) A5 o& t7 u![]()
& I# N) W0 r/ t4 e n
6 U3 [% x+ y$ ?7 C( R
: p- `% f; {0 G1 @' R$ s; H可见,当 di > 0时,表示有di 个单位的流量从网络外部流入该顶点,因此顶点i 称 为供应点(supply node)或源(source),有时也形象地称为起始点或发点等;当di < 0 时,表示有|di | 个单位的流量从该顶点流失到网络外部(或说被该顶点吸收),因此顶 点i 称为需求点(demand node)或汇(sink),有时也形象地称为终止点或收点等;当 di = 0时,顶点i 称为转运点(transshipment node)或平衡点、中间点等。此外,根据 (1)可知,对于可行网络,必有
3 `+ J4 e8 r! Z" s+ W9 ?9 w
# i' f8 r% m" J& z; K![]()
9 ?8 B) x9 i( n$ A. z5 F8 `, Q* y$ ~2 _* `1 i* t" F3 @: e
也就是说,所有节点上的供需量之和为 0 是网络中存在可行流的必要条件
- T7 \. y8 Q- j0 K4 C& T; L: M" d1 p! {8 G$ @( ^5 a7 ~5 F
6 |" D4 n& P+ `& c, i4 L
![]()
4 H7 H3 ]0 X" \3 h
% j( ~( Z( i" F J* j1.2 最大流问题
& L' w1 v& E8 X8 e8 |考虑如下流网络 N = (V, A,U,D):节点 s 为网络中唯一的源点,t 为唯一的汇点, 而其它节点为转运点。如果网络中存在可行流 f ,此时称流 f 的流量(或流值,flow value)为 (根据(3),它自然也等于 − ),通常记为v 或v( f ) ,即
& @, }- }( w7 ^9 L) Z( k1 M# i7 Z
' I% k/ R) ]8 \7 \$ g 9 Q: E7 G6 P, S( N& Z; l
对这种单源单汇的网络,如果我们并不给定 和 (即流量不给定),则网络一 般记为 N = (s,t,V, A,U) 。最大流问题( maximum flow problem )就是在 N = (s,t,V, A,U) 中找到流值最大的可行流(即最大流)。我们将会看到,最大流问题 的许多算法也可以用来求解流量给定的网络中的可行流。也就是说,当我们解决了最大 流问题以后,对于在流量给定的网络中寻找可行流的问题,通常也就可以解决了。. m( H s2 n" K }7 T" i' ^
- S& j+ K S% N3 o; Y
用线性规划描述最大流问题
5 k& Q- W2 y6 o4 M因此,用线性规划的方法,最大流问题可以形式地描述如下:! p0 S7 D8 q+ \* @$ ?5 ]
# G; |- J$ l* s6 w1 A/ v
![]()
w# E% c" W( D: W. d8 `' M) p" N9 |: Y0 X" e0 s9 K8 o
定义】 如果一个矩阵 A 的任何子方阵的行列式的值都等于0,1或 −1,则称 A 是 全幺模的(totally unimodular TU,又译为全单位模的),或称 A 是全幺模矩阵。
' c1 x4 i0 M7 H; S0 ^" _6 P4 E. m+ s/ _5 T4 [' [$ H" u" L0 ^
整流定理; _( {- j% d1 P( A
【定理 7】(整流定理) 最大流问题所对应的约束矩阵是全幺模矩阵。若所有弧容量 均为正整数,则问题的最优解为整数解。 最大流问题是一个特殊的线性规划问题。我们将会看到利用图的特点,解决这个问 题的方法较之线性规划的一般方法要方便、直观得多。
, o+ q5 {9 a m& L4 J) t
' Q' I& O; }9 q- h1.3 单源和单汇运输网络
) V: w6 `: @" p. q& z$ T多源多汇网络 转化成单源单汇网络- D2 T$ |1 A5 H8 Y' h
实际问题往往是多源多汇网络,为了计算的规格化,可将多源多汇网络G 化成单 源单汇网络G' 。设 X 是G 的源,Y 是G 的汇,具体转化方法如下:/ P" U- u3 d L9 T+ C
9 W* E8 Y# D6 E1 m+ z; `- x(i)在原图G 中增加两个新的顶点 x 和 y ,令为新图G' 中之单源和单汇,则G 中 所有顶点V 成为G' 之中间顶点集。
- r/ V3 P7 P% D" z
7 r! e: E% H/ a: D(ii)用一条容量为∞的弧把 x 连接到 X 中的每个顶点。- Z- ] R# E8 J$ c
) y6 f; N$ n7 ]0 q1 z(iii)用一条容量为∞的弧把Y 中的每个顶点连接到 y 。 G 和G' 中的流以一个简单的方式相互对应。若 f 是G 中的流,则由
8 }6 r9 O4 v$ @/ d5 j' Q/ J4 C. ^; `( H" |$ S
% B2 R t+ `6 T* j+ M- m
( {' i( n; Z6 v7 ` d8 \. k( w2 最大流和最小割关系割的容量 8 z3 C5 u1 k* i4 h! G% T" F
7 I9 \" w0 T) b% Y! ^# b3 ?
1 m) l9 a( }1 \) D4 [) A
1 t! r) c, Y3 M) A- s( F
则在这条可增广轨上每条前向弧的流都可以增加一个量δ ,而相应的后向弧的流可减 少δ ,这样就可使得网络的流量获得增加,同时可以使每条弧的流量不超过它的容量, 而且保持为正,也不影响其它弧的流量。总之,网络中 f 可增广轨的存在是有意义的, 因为这意味着 f 不是最大流。. e% q4 `0 ?1 W$ i6 g; _" E8 S
' Q5 e+ E9 S) w _% x L
3 最大流的一种算法—标号法
6 g, _0 B0 o2 n! K0 O) c$ X6 S9 b6 k标号法是由 Ford 和 Fulkerson 在 1957 年提出的。用标号法寻求网络中最大流的基 本思想是寻找可增广轨,使网络的流量得到增加,直到最大为止。即首先给出一个初始 流,这样的流是存在的,例如零流。如果存在关于它的可增广轨,那么调整该轨上每条 弧上的流量,就可以得到新的流。对于新的流,如果仍存在可增广轨,则用同样的方法 使流的值增大,继续这个过程,直到网络中不存在关于新得到流的可增广轨为止,则该 流就是所求的最大流。' M5 F4 N3 [: m( n7 u
, M8 _6 G3 H& I q) S这种方法分为以下两个过程:, M- k* ]; _; K1 V* S2 ]1 O
% O1 n3 j1 [+ a5 j2 m7 `
A.标号过程:通过标号过程寻找一条可增广轨。
" j, A4 Y* T X) \
- f- r. h/ z0 JB.增流过程:沿着可增广轨增加网络的流量。4 Y6 Y. d& g" G/ W
# S- |5 k! \- D9 U4 S! _: i, [这两个过程的步骤分述如下。
4 T# {; z" p1 @
& _/ u" [% a4 p7 ~(A)标号过程:
6 H$ d+ M& }- ~; n% F7 ^9 N
. B- D+ ` j* n4 q+ J: M* O 2 }2 Y8 g8 J) Z& N8 l
# p7 y: F1 X3 a# @" L
(B)增流过程![]()
5 D7 o( v6 ~7 r" H9 u6 ]8 N
5 ^; y# [, E5 e h$ X网络最大流 x 的求解步骤
9 Q; F& ?" Q4 _1 f3 s求网络 N = (s,t,V, A,U) 中的最大流 x 的算法的程序设计具体步骤如下:
# w6 M( s. V, }
$ F( W( s+ n9 V" N i/ s对每个节点 j ,其标号包括两部分信息 (pred( j),maxf(j))
9 V8 ]1 B4 k- w [1 N
! P9 y# p# X0 w6 |2 }该节点在可能的增广路中的前一个节点 pred( j) ,以及沿该可能的增广路到该节点为止 可以增广的最大流量 maxf( j)。
' _3 j7 K7 N/ N' r+ Z, n0 K
5 |2 G1 D5 s7 t$ y& q6 w. A![]()
5 |0 p+ a# d& @$ ~' b _3 ]/ ~2 R' g/ e* O6 `4 t0 u& k6 K
并将 j 加入 LIST 中。 例 17 用 Ford-Fulkerson 算法计算如图 6 网络中的最大流,每条弧上的两个数字分 别表示容量和当前流量。 ![]()
( A2 w Z8 g$ }) i2 ~; [5 _, }- }# I8 C6 z4 \
) H3 o5 @8 L+ a' [0 J; q5 Q% r
解 编写程序如下:4 v! S' y4 C7 h( @) ~
. ?5 c8 H [! o
clc,clear, J3 K5 n6 E2 O/ w6 h) g. B
u(1,2)=1;u(1,3)=1;u(1,4)=2;u(2,3)=1;u(2,5)=2;
6 o* z. j' Q, Bu(3,5)=1;u(4,3)=3;u(4,5)=3;
9 ^- L5 G; s- U1 ?. o ?9 h* cf(1,2)=1;f(1,3)=0;f(1,4)=1;f(2,3)=0;f(2,5)=1;6 R% R! D U2 A) e4 A/ Y/ W) ^
f(3,5)=1;f(4,3)=1;f(4,5)=0;
; ~5 e" V# Y% Z9 K9 s0 d8 h( z: Yn=length(u);list=[];maxf(n)=1;
* y; H, ?. Y' e3 vwhile maxf(n)>06 e& T( B/ X. U8 x0 V+ S" O7 b
maxf=zeros(1,n);pred=zeros(1,n);, o3 o4 @2 H1 [ c" W3 z9 [( i. H
list=1;record=list;maxf(1)=inf;
; U6 F+ c8 L$ @: [. E" ~ % list是未检查邻接点的标号点,record是已标号点) r5 G ]) m1 ?; n1 l
while (~isempty(list))&(maxf(n)==0)
1 ?: c, W+ A( k" l flag=list(1);list(1)=[];7 X/ ], q* g# C1 C
label1= find(u(flag, -f(flag, );, H# J3 Z. @4 k# F6 T5 r
label1=setdiff(label1,record);% w0 U1 {; b' u
list=union(list,label1);
' @) v! h# l! } pred(label1)=flag;1 q, w t/ A$ } Z) h
maxf(label1)=min(maxf(flag),u(flag,label1).... w# Z& R6 C! U7 {+ ^6 M
-f(flag,label1));
7 e: d6 w6 H# W' Y8 ] record=union(record,label1);
* N/ n+ W/ L5 X" _ label2=find(f(:,flag));4 T9 K4 D/ O% V2 q. ~
label2=label2';. y: o. I- P6 r4 K/ f& g
label2=setdiff(label2,record);6 |( a( L7 k8 M. W5 J1 L
list=union(list,label2);
3 O( f& N9 q* l& Z( L; _+ z pred(label2)=-flag;$ F+ G! M+ {0 e2 W t9 x+ |: D5 U5 Y
maxf(label2)=min(maxf(flag),f(label2,flag));( i8 B3 f$ k! g$ T
record=union(record,label2);/ ^$ l% X3 s, p/ O% U; w" A
end, D' {/ T( q% q- N7 i! ?
if maxf(n)>09 h. m/ k& B$ ?
v2=n; v1=pred(v2);5 m% @; A$ E2 n! L, E0 j
while v2~=1: C9 r6 E' Q: Z
if v1>0% c9 X k# a5 ]
f(v1,v2)=f(v1,v2)+maxf(n);# b# S: J( I, b
else, x$ |% g. F- p8 j4 r" v
v1=abs(v1);/ [ `& C' F9 h& L: D; C
f(v2,v1)=f(v2,v1)-maxf(n);
4 F* P' w7 s% b4 x ~7 N5 c; X end$ x+ S0 B+ t7 r: K3 P7 E$ b
v2=v1; v1=pred(v2);$ x$ C) g3 `" [- r( V5 I; N% j
end# t9 W- Q( T5 e
end
U; o# q7 V& g# e8 w+ B9 u5 ~end
: p- L+ e5 a( B4 x4 {: I2 Mf % L0 | L( ?1 v; j. s
例18 现需要将城市 s 的石油通过管道运送到城市t ,中间有4个中转站 v1 ,v2 ,v3 和 v4 ,城市与中转站的连接以及管道的容量如图7所示,求从城市 s 到城市t 的最大流。3 i M' R7 |2 c3 b1 _* A' O
( R& Z6 _7 Z. t( @& |
) Z8 g& l+ s5 G. A![]()
2 M4 `- L& K% Q, x: f- E- L* y5 Q& q2 F! D, Z( @3 L
解 使用最大流的数学规划表达式,编写LINGO程序如下:
0 t& [2 r3 l% |6 i5 [" s# A8 x; W/ h p) ` A4 U
model:
+ a. t* h. V6 i g# e3 Dsets:) K- |6 m( L! g# Y
nodes/s,1,2,3,4,t/;' W- a1 U& q) `' @1 P- M
arcs(nodes,nodes)/s 1,s 3,1 2,1 3,2 3,2 t,3 4,4 2,4 t/:c,f;
1 L( I+ W V9 `1 Yendsets# ?8 B0 p# C f
data:4 I8 k4 a. r" e
c=8 7 9 5 2 5 9 6 10;+ u. a$ T- ~+ K
enddata! {. v+ u4 Q0 q8 L
n=@size(nodes); !顶点的个数;5 v$ K6 p$ [" q4 q* P! n) x& C
max=flow;1 V* _0 y" P9 A! G/ r2 f, C
@for(nodes(i)|i #ne#1 #and# i #ne# n:
: C- Y4 H& G( O! h. R @sum(arcs(i,j):f(i,j))=@sum(arcs(j,i):f(j,i). H# G9 s9 P, E. D( o
@sum(arcs(i,j)|i #eq# 1:f(i,j))=flow;
* Z: M0 H. k. \" m@sum(arcs(i,j)|j #eq# n:f(i,j))=flow;
2 {8 R! I5 Q4 s0 P2 }@for(arcs bnd(0,f,c));
% ]) v5 ]$ K. ^* uend 4 y% p6 C4 b7 _( L( v# S, N: k
/ a. J. ?! q+ S) z. v在上面的程序中,采用了稀疏集的编写方法。下面介绍的程序编写方法是利用赋权邻 接矩阵,这样可以不使用稀疏集的编写方法,更便于推广到复杂网络。
/ ^4 H6 ~7 I C y7 s* M$ _$ }
) x; t4 b) R. omodel:9 B) o) d2 R0 p4 n) W
sets:% |6 h8 {- g' y
nodes/s,1,2,3,4,t/;. Z7 w: b9 ]0 j/ n/ ^
arcs(nodes,nodes):c,f;$ }9 P+ z! B3 L3 P! y" K+ K
endsets0 u$ N9 `1 w$ K$ `1 l
data:. Q) `: J q' I4 X" a: B% O
c=0;
1 Z2 M& r$ I; ^@text('fdata.txt')=f;4 [) B3 }$ G3 Z! X* `' f/ _
enddata }0 t$ h7 h% H: Y: z# G! g5 Q1 k
calc:
( X& Z3 G. r+ _8 ?" T; Yc(1,2)=8;c(1,4)=7;* U& r. s) Z" ]8 R
c(2,3)=9;c(2,4)=5;
) T: V/ `- d# s: Y+ gc(3,4)=2;c(3,6)=5;
/ V0 y6 Q. m* t- }2 H. e) z4 Nc(4,5)=9;c(5,3)=6;c(5,6)=10;) t- d8 v5 n) }8 k& D
endcalc
& z" m8 f' a4 C) `3 j/ zn=@size(nodes); !顶点的个数;
2 ~8 W x/ J, pmax=flow;
1 T; |( [8 f* x/ j' ]@for(nodes(i)|i #ne#1 #and# i #ne# n:5 G5 I3 ? F" l5 u) P- K
@sum(nodes(j):f(i,j))=@sum(nodes(j):f(j,i)));$ i3 [- j, S/ q, \" u
@sum(nodes(i):f(1,i))=flow;
7 E$ @0 j+ B; P, }6 o, i! ?/ P" `@sum(nodes(i):f(i,n))=flow;
; W0 W5 u6 d1 h0 ?@for(arcs bnd(0,f,c));0 v2 d3 [/ [- Z, w
end
8 O/ C, T) S. v/ w" p s( c
$ F: q& S. r4 l! X2 B* m, h————————————————+ r3 q+ e1 }& W1 S. U9 B) D$ T n
版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。/ B$ b1 ~# _" b2 E+ D
原文链接:https://blog.csdn.net/qq_29831163/article/details/89786313
: z# E7 {8 {' `- n H0 u* a& [: f/ K: \
. i8 |, j9 d+ J; ^% X |
zan
|