数学建模社区-数学中国

标题: 常用模型&算法总结—图&网络模型应用—树:连通性、最小生成树 [打印本页]

作者: 浅夏110    时间: 2020-5-21 09:56
标题: 常用模型&算法总结—图&网络模型应用—树:连通性、最小生成树
1 最大流问题的数学描述
, _6 ~3 Z8 `  ?  L- C' [1.1 网络中的流 定义
- E% G, p( `* w1 C' {2 X在以V 为节点集, A 为弧集的有向图G = (V, A) 上定义如下的权函数:/ C/ r# N! h8 a* V# d

; V+ ?8 R6 \  y/ t3 B" \* M(i) L : A → R 为孤上的权函数,弧 (i, j)∈ A 对应的权 L(i, j) 记为 ,称为孤 (i, j) 的容量下界(lower bound);
3 _" Q$ T0 Q6 H. `$ X
+ ]2 [! n4 X* z1 Z+ H8 p" Y2 c(ii)U : A → R 为弧上的权函数,弧(i, j)∈ A对应的权U(i, j) 记为 ,称为孤 (i, j) 的容量上界或容量(capacity);6 w! R, A% Y2 V% m. K! k

/ _% q, z# Z" _. M" e. B(iii) D :V → R 为顶点上的权函数,节点i ∈V 对应的权 D(i) 记为  ,称为顶 点i 的供需量(supply/demand);
6 F' H1 x0 a+ k! A) }9 u* z9 w, j3 k! X& p) p) D2 M
此时所构成的网络称为流网络,可以记为 N = (V, A, L,U,D) 。 由于我们只讨论V, A 为有限集合的情况,所以对于弧上的权函数 L,U 和顶点上的 权函数 D ,可以直接用所有孤上对应的权和顶点上的权组成的有限维向量表示,因此 L,U, D 有时直接称为权向量,或简称权。由于给定有向图G = (V, A) 后,我们总是可 以在它的弧集合和顶点集合上定义各种权函数,所以流网络一般也直接简称为网络。  e% T9 Y1 A% m. i; P5 e3 W

& {" U- ]/ _$ Y* r0 L在流网络中,弧(i, j) 的容量下界  和容量上界表示的物理意义分别是:通过该 弧发送某种“物质”时,必须发送的最小数量为 ,而发送的最大数量为 。顶点i ∈V 对应的供需量则表示该顶点从网络外部获得的“物质”数量( > 0时),或从该顶 点发送到网络外部的“物质”数量(< 0 时)。下面我们给出严格定义。: R$ S: \6 r8 F
9 Q5 [# f$ \, T# B) R+ [; m
可行流(feasible flow)9 C9 o# z: j9 {0 w" f, V
) Y6 k/ @! i% y9 r0 @5 ^* O, _
5 S! v. {9 F8 J' w& O

; |! u. |) I2 B* ], n) v
4 {0 X9 Q  v# E& X: o! S可见,当 di > 0时,表示有di 个单位的流量从网络外部流入该顶点,因此顶点i 称 为供应点(supply node)或源(source),有时也形象地称为起始点或发点等;当di < 0 时,表示有|di | 个单位的流量从该顶点流失到网络外部(或说被该顶点吸收),因此顶 点i 称为需求点(demand node)或汇(sink),有时也形象地称为终止点或收点等;当 di = 0时,顶点i 称为转运点(transshipment node)或平衡点、中间点等。此外,根据 (1)可知,对于可行网络,必有5 _( H- c' b: ~/ \

; W/ e: w, u: O# v, u
& r) C3 P, o4 F3 B7 F' A$ i9 S
. K+ [% l! t" B6 v也就是说,所有节点上的供需量之和为 0 是网络中存在可行流的必要条件1 R$ e  b4 ?$ g4 F% U
" |% `' q' {, x' }0 |  v

, ~; t& F  }6 q- h
3 k" j3 }1 M6 j+ Y- i
8 ]# g# L) _6 ~( D! q# C1.2 最大流问题; R2 d: W8 C/ u# a8 F& i5 Q( q
考虑如下流网络 N = (V, A,U,D):节点 s 为网络中唯一的源点,t 为唯一的汇点, 而其它节点为转运点。如果网络中存在可行流 f ,此时称流 f 的流量(或流值,flow value)为 (根据(3),它自然也等于 −  ),通常记为v 或v( f ) ,即
5 ?: v( K! m( B& G
. ~/ Y& I+ u% ?5 z( S3 z" r; z6 R7 E
- D% {/ l" |3 N! j4 n" ~% P# ~8 ~对这种单源单汇的网络,如果我们并不给定  和  (即流量不给定),则网络一 般记为 N = (s,t,V, A,U) 。最大流问题( maximum flow problem )就是在 N = (s,t,V, A,U) 中找到流值最大的可行流(即最大流)。我们将会看到,最大流问题 的许多算法也可以用来求解流量给定的网络中的可行流。也就是说,当我们解决了最大 流问题以后,对于在流量给定的网络中寻找可行流的问题,通常也就可以解决了。
* N9 Y  D0 |+ o! {% Q, C( x9 Y4 L% D# e$ b
用线性规划描述最大流问题
4 r3 K  `) L( H1 e( i因此,用线性规划的方法,最大流问题可以形式地描述如下:* e1 E) a- r6 Z& N1 E0 [

. P! s6 {: ]$ Q/ |. l: ~9 o' t+ B7 L

" d$ p% F6 t3 a+ V0 r定义】 如果一个矩阵 A 的任何子方阵的行列式的值都等于0,1或 −1,则称 A 是 全幺模的(totally unimodular TU,又译为全单位模的),或称 A 是全幺模矩阵。1 e; ]6 A% V5 R

8 L- a/ A- e' }- l# _; x0 Y整流定理
1 D! m) a" `, y6 }- {  K/ Z【定理 7】(整流定理) 最大流问题所对应的约束矩阵是全幺模矩阵。若所有弧容量 均为正整数,则问题的最优解为整数解。 最大流问题是一个特殊的线性规划问题。我们将会看到利用图的特点,解决这个问 题的方法较之线性规划的一般方法要方便、直观得多。7 ^# d  M0 f/ L8 k* h$ E; C

0 W4 [* H0 G# ]' ]0 t' o- I1.3 单源和单汇运输网络
- ^% _, ]! }4 I$ n/ g& ~  i多源多汇网络 转化成单源单汇网络9 y4 F, o! G# y+ Y
实际问题往往是多源多汇网络,为了计算的规格化,可将多源多汇网络G 化成单 源单汇网络G' 。设 X 是G 的源,Y 是G 的汇,具体转化方法如下:  _9 j: R+ t9 {3 v2 A$ E, x1 T+ E
& [) x, ~  e4 c3 }, R
(i)在原图G 中增加两个新的顶点 x 和 y ,令为新图G' 中之单源和单汇,则G 中 所有顶点V 成为G' 之中间顶点集。& o7 D' L! v+ S! z! F5 }) H

6 C+ Y" `7 L- \8 [0 }& L4 }(ii)用一条容量为∞的弧把 x 连接到 X 中的每个顶点。, e/ A. \# K; o( I. h& z
* |& e) p/ h; |$ E* u
(iii)用一条容量为∞的弧把Y 中的每个顶点连接到 y 。 G 和G' 中的流以一个简单的方式相互对应。若 f 是G 中的流,则由3 G3 r3 N- p3 L

2 S! t! U9 j( w$ J% H8 s# i; J9 d6 H$ [8 ^) e
9 ~# D5 X+ I5 p/ L% G  s6 k, Q( k
2 最大流和最小割关系割的容量2 L5 F6 j0 F7 l

8 I# e6 _; q( M1 n: A( Z0 K# {. {  S! d

  c1 t' _7 i- p2 o" P: f( O则在这条可增广轨上每条前向弧的流都可以增加一个量δ ,而相应的后向弧的流可减 少δ ,这样就可使得网络的流量获得增加,同时可以使每条弧的流量不超过它的容量, 而且保持为正,也不影响其它弧的流量。总之,网络中 f 可增广轨的存在是有意义的, 因为这意味着 f 不是最大流。
8 B- j, J. c" B  g7 P' Y; m
) R: v, V4 @9 l  l+ C% {  T3 最大流的一种算法—标号法
; {- E& E' T# h" k2 `标号法是由 Ford 和 Fulkerson 在 1957 年提出的。用标号法寻求网络中最大流的基 本思想是寻找可增广轨,使网络的流量得到增加,直到最大为止。即首先给出一个初始 流,这样的流是存在的,例如零流。如果存在关于它的可增广轨,那么调整该轨上每条 弧上的流量,就可以得到新的流。对于新的流,如果仍存在可增广轨,则用同样的方法 使流的值增大,继续这个过程,直到网络中不存在关于新得到流的可增广轨为止,则该 流就是所求的最大流。& I4 q. }- U' p/ D- u
- r2 Y& M, _; Y/ V
这种方法分为以下两个过程:) X% Z3 `) H6 E- U# T, s* x7 W
9 L( I' m, R2 v2 l4 j
A.标号过程:通过标号过程寻找一条可增广轨。
8 l0 }5 j7 W& s6 f
3 ~+ ~$ s- ~; IB.增流过程:沿着可增广轨增加网络的流量。
# R0 Y# g/ D0 |6 t1 p+ c$ [# U; O2 h' e! d
这两个过程的步骤分述如下。) S" p- ?0 \2 ~" e% Z. X5 y
; y! m! G! _# U
(A)标号过程:
. \9 z" s$ l* Z# K
! @" {% e/ S: h2 A% a# P. b; W  q, S# N0 ]2 c

+ e1 [  d; }3 a5 a(B)增流过程8 r! x2 C- B0 P0 l, j
0 {. w1 H, S8 r9 {# F& ~- K
网络最大流 x 的求解步骤, B- ~  Y* P7 \6 V
求网络 N = (s,t,V, A,U) 中的最大流 x 的算法的程序设计具体步骤如下:
9 i5 O( E% O+ T
* g0 q' [) z/ F$ C5 N对每个节点 j ,其标号包括两部分信息 (pred( j),maxf(j)); M! M* L# Y; _4 `& d( k# Z/ H! N; u

* e) a* V" M: m该节点在可能的增广路中的前一个节点 pred( j) ,以及沿该可能的增广路到该节点为止 可以增广的最大流量 maxf( j)。* b1 F4 X  @8 J. q) h- l

' n: k& [7 K3 {1 N" |* W% l; ~
0 \- A, ?! P0 k- u) C( u; j+ C4 t. o% O/ a

并将 j 加入 LIST 中。

例 17 用 Ford-Fulkerson 算法计算如图 6 网络中的最大流,每条弧上的两个数字分 别表示容量和当前流量。


1 U/ Q1 J# v  ]- R0 }( ?
  k. z4 q8 n2 O$ r1 t9 h, x$ ?8 W
解 编写程序如下:- ]6 t4 V  R; f0 Y  ~; O6 H
4 f# O, x" \4 t/ O. W2 l
clc,clear
3 Z' Y4 y. d$ c0 V: A# ]: r4 fu(1,2)=1;u(1,3)=1;u(1,4)=2;u(2,3)=1;u(2,5)=2;- W8 S8 `: o/ y) {/ P4 {
u(3,5)=1;u(4,3)=3;u(4,5)=3;
! J6 p' F* G$ t6 w1 i2 O6 o4 zf(1,2)=1;f(1,3)=0;f(1,4)=1;f(2,3)=0;f(2,5)=1;5 T5 I% G2 K" m% E% m& q, W* Y
f(3,5)=1;f(4,3)=1;f(4,5)=0;
9 }; l6 s0 W9 vn=length(u);list=[];maxf(n)=1;
) Q: r- ?/ [4 ?while maxf(n)>0/ Q- s. r; ~# J5 z3 g  v2 o
maxf=zeros(1,n);pred=zeros(1,n);
" H6 b# R+ C3 p- p! Tlist=1;record=list;maxf(1)=inf;
7 ]0 a3 |3 U! v' y% Z8 F % list是未检查邻接点的标号点,record是已标号点8 X1 J) }2 J! l, F. [- [
while (~isempty(list))&(maxf(n)==0)$ |) C8 C: X8 v* S
    flag=list(1);list(1)=[];
$ k3 o$ m1 O, P: z  Q& |    label1= find(u(flag,-f(flag,);
/ n- r$ S9 ^& \- s: g7 G4 n4 |    label1=setdiff(label1,record);( D# p# C: t6 D
    list=union(list,label1);' f. Q' v. \" e0 w  d  c
    pred(label1)=flag;: M3 N+ ?* G4 F  Q2 {' [, R
    maxf(label1)=min(maxf(flag),u(flag,label1)...7 J0 b2 l; r% I7 ]  D
    -f(flag,label1));( i1 M5 i0 K% N8 ~+ W! b
    record=union(record,label1);. X/ A# x' t" v  k' U6 E
    label2=find(f(:,flag));; i, K$ H" k0 j/ L# w) x" T1 k  g
    label2=label2';9 H' I* Z' a3 s# x* _# w2 T' x
    label2=setdiff(label2,record);3 @# B, t) h# J9 p  F
    list=union(list,label2);* `+ X4 G; J- R3 |! e
    pred(label2)=-flag;8 {* ~5 Z) \) c. J0 b
    maxf(label2)=min(maxf(flag),f(label2,flag));
# r" \" T0 X) I9 Y9 z    record=union(record,label2);
3 ~6 D, J3 y4 t7 a! Z end
& K: Q# x, v9 y/ S9 k! K2 ~8 U) |     if maxf(n)>0
( s$ X9 R) c9 H1 a6 u. v: |        v2=n; v1=pred(v2);
' [' K3 M) `" \* s* g- O        while v2~=1
/ h; Q1 Q9 R5 q( j4 _& J- e            if v1>0/ V* g- J5 `! H! j
                f(v1,v2)=f(v1,v2)+maxf(n);4 T( m( w( x3 C8 [
            else
5 h+ s* e6 _' S* C                v1=abs(v1);
# `1 B. v" v; U                f(v2,v1)=f(v2,v1)-maxf(n);; n' r6 w; }3 b0 N3 D
            end3 d( p/ X; T/ j$ w
            v2=v1; v1=pred(v2);
/ c$ H1 v! d! g, _: v8 v        end* P* c- W2 }# R$ z; B+ m
    end
8 s5 X2 u6 F+ X, z0 l" Q4 aend
/ {1 }; c; B8 I6 |: @. {f
2 @7 u7 j6 Y3 ~! d例18 现需要将城市 s 的石油通过管道运送到城市t ,中间有4个中转站  v1 ,v2 ,v3 和  v4 ,城市与中转站的连接以及管道的容量如图7所示,求从城市 s 到城市t 的最大流。
' q3 f% g: |( n- d! U- g2 |
$ L' f& l  @7 b" [5 c0 V& S0 F  O6 A' M; s4 I/ \  h! \

7 }' _5 a# i& ~
1 j. ~1 E0 [# j4 g解 使用最大流的数学规划表达式,编写LINGO程序如下:
" q+ ?3 U* w. ~
. \* }! \. d  tmodel:
9 {) Z: O9 K, g( Q* xsets:" V5 ?1 i4 N" J+ n) k- g: A
nodes/s,1,2,3,4,t/;" {0 @! ^7 U% k5 ?. l$ V# {% ^5 s! e
arcs(nodes,nodes)/s 1,s 3,1 2,1 3,2 3,2 t,3 4,4 2,4 t/:c,f;7 k: K6 f( E7 m
endsets
0 R# `+ z3 M# f7 {# xdata:
; \2 ?! D' k- c: Bc=8 7 9 5 2 5 9 6 10;
' p) s0 G% G1 ~$ [3 x( P: Genddata
' J* p* f) R+ N9 Jn=@size(nodes); !顶点的个数;! ?. w$ c8 Y9 Q( p: m
max=flow;3 Q  w4 f8 H3 N9 {
@for(nodes(i)|i #ne#1 #and# i #ne# n:
, L4 O, a1 Z) x( K    @sum(arcs(i,j):f(i,j))=@sum(arcs(j,i):f(j,i)
* e/ x  p$ v: ?) a@sum(arcs(i,j)|i #eq# 1:f(i,j))=flow;: }! m* E/ L$ z  R- K2 j/ W
@sum(arcs(i,j)|j #eq# n:f(i,j))=flow;
2 U/ q8 j2 ^/ M, o" N! ]@for(arcsbnd(0,f,c));) c! `0 W# H/ J% Z+ }: J! v; j
end ( U, B) A. f) t# k* g* g  e0 L

  s7 e' p5 u) i# X  ]在上面的程序中,采用了稀疏集的编写方法。下面介绍的程序编写方法是利用赋权邻 接矩阵,这样可以不使用稀疏集的编写方法,更便于推广到复杂网络。, k2 C$ n' O3 h* j! M  }6 Y
, ]0 S: U: g  |/ n. K) T: L
model:# a0 h: }6 ]* G) Q8 F- _
sets:
. v6 C( X, ^+ z2 K2 @7 |6 Nnodes/s,1,2,3,4,t/;9 [4 x8 y. F" G3 P" _
arcs(nodes,nodes):c,f;
- h2 u& r: r; y: B& F+ E% uendsets+ k2 v% _" X9 N: _6 D% o' d
data:+ v# W) m0 k5 R, H6 Z* I
c=0;* F7 `- n' N' o6 T( v
@text('fdata.txt')=f;
0 [8 j% z9 z) I$ o7 [$ e1 Qenddata
: ]' g8 h+ i2 ]  W3 lcalc:7 J0 e2 l1 S6 R4 j4 {
c(1,2)=8;c(1,4)=7;
0 r( {6 _9 p: T* O1 g2 _1 y4 Sc(2,3)=9;c(2,4)=5;
6 w" d4 n1 q$ H: Qc(3,4)=2;c(3,6)=5;
5 k& Y) b9 W" s/ k8 [+ Q: B+ Rc(4,5)=9;c(5,3)=6;c(5,6)=10;; K* e- g4 D; ^6 Q, w- o
endcalc
' |* y( i( ]( G6 K9 t, X* tn=@size(nodes); !顶点的个数;
% j, ]; D0 B0 f6 c0 M* M' z1 @max=flow;# _2 l! K$ Z" V0 V$ w% B5 j  i4 T
@for(nodes(i)|i #ne#1 #and# i #ne# n:. ~( V. C7 I( m, B; d. @
    @sum(nodes(j):f(i,j))=@sum(nodes(j):f(j,i)));
5 {$ E; j: _1 U! J@sum(nodes(i):f(1,i))=flow;
8 Y) O- Z3 ^# F; d/ Q( l2 b@sum(nodes(i):f(i,n))=flow;$ c! t  c8 G1 O& t, L
@for(arcsbnd(0,f,c));% g" }' u2 ]7 F$ c& l8 ~+ T3 j) V
end4 ]2 k( ^- |9 q. Y" I. j
2 C( L6 |0 X0 w0 [1 u
————————————————
; C4 d$ k1 e- p6 Z5 E版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。9 ]5 g' n; {1 e) t
原文链接:https://blog.csdn.net/qq_29831163/article/details/897863132 T. d) N; @: B
. J. ?0 z! s6 J7 L. V

7 B+ n+ \, A# A( c




欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) Powered by Discuz! X2.5