QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1815|回复: 0
打印 上一主题 下一主题

常用模型&算法总结—图&网络模型应用—树:连通性、最小生成树

[复制链接]
字体大小: 正常 放大
浅夏110 实名认证       

542

主题

15

听众

1万

积分

  • TA的每日心情
    开心
    2020-11-14 17:15
  • 签到天数: 74 天

    [LV.6]常住居民II

    邮箱绑定达人

    群组2019美赛冲刺课程

    群组站长地区赛培训

    群组2019考研数学 桃子老师

    群组2018教师培训(呼伦贝

    群组2019考研数学 站长系列

    跳转到指定楼层
    1#
    发表于 2020-5-21 09:56 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta |邮箱已经成功绑定
    1 最大流问题的数学描述
    7 K+ R6 y( o  `1.1 网络中的流 定义, N! r; E# P! W
    在以V 为节点集, A 为弧集的有向图G = (V, A) 上定义如下的权函数:+ h* Z/ O- f7 i7 E& O

    6 u/ V+ h& q  N0 l; @(i) L : A → R 为孤上的权函数,弧 (i, j)∈ A 对应的权 L(i, j) 记为 ,称为孤 (i, j) 的容量下界(lower bound);% y$ c7 M$ ?& D+ B$ v* \
    0 m/ `  t- L7 n1 M& S
    (ii)U : A → R 为弧上的权函数,弧(i, j)∈ A对应的权U(i, j) 记为 ,称为孤 (i, j) 的容量上界或容量(capacity);1 o; w: v' b. J( E, u% {
    " J% T/ v. g+ W9 }, O$ H4 _% @
    (iii) D :V → R 为顶点上的权函数,节点i ∈V 对应的权 D(i) 记为  ,称为顶 点i 的供需量(supply/demand);6 ~/ a2 v$ x5 e  i  D  D: g
    % P3 @! [+ p; d, i
    此时所构成的网络称为流网络,可以记为 N = (V, A, L,U,D) 。 由于我们只讨论V, A 为有限集合的情况,所以对于弧上的权函数 L,U 和顶点上的 权函数 D ,可以直接用所有孤上对应的权和顶点上的权组成的有限维向量表示,因此 L,U, D 有时直接称为权向量,或简称权。由于给定有向图G = (V, A) 后,我们总是可 以在它的弧集合和顶点集合上定义各种权函数,所以流网络一般也直接简称为网络。/ v3 Q6 c2 a  b8 y: d0 ^+ q
    . \* P7 P) ?2 p( |: o1 j$ t
    在流网络中,弧(i, j) 的容量下界  和容量上界表示的物理意义分别是:通过该 弧发送某种“物质”时,必须发送的最小数量为 ,而发送的最大数量为 。顶点i ∈V 对应的供需量则表示该顶点从网络外部获得的“物质”数量( > 0时),或从该顶 点发送到网络外部的“物质”数量(< 0 时)。下面我们给出严格定义。& y1 U9 F9 J# H. p

    8 ]6 d$ s7 I' l; F1 ~3 J! B/ S) L可行流(feasible flow)$ N7 v8 Q/ [5 e% v# f" S8 z% o1 g4 X2 m

    2 [- ~/ J9 H# c& a5 a
    $ W3 Q& i4 D7 A+ t+ b. d) e" s" a$ U

    8 P: R5 G9 j; \7 M% t9 c) Z可见,当 di > 0时,表示有di 个单位的流量从网络外部流入该顶点,因此顶点i 称 为供应点(supply node)或源(source),有时也形象地称为起始点或发点等;当di < 0 时,表示有|di | 个单位的流量从该顶点流失到网络外部(或说被该顶点吸收),因此顶 点i 称为需求点(demand node)或汇(sink),有时也形象地称为终止点或收点等;当 di = 0时,顶点i 称为转运点(transshipment node)或平衡点、中间点等。此外,根据 (1)可知,对于可行网络,必有
    ' k: [$ G  c0 Y+ j3 p. M- x. B! w( r, E% ~3 Y
    ) E- B9 v( k1 z. {! X; ^

    3 o5 b6 l" _% S1 D也就是说,所有节点上的供需量之和为 0 是网络中存在可行流的必要条件! C0 p5 p+ X4 s7 R0 V6 {

    ( h' `" l. K# e5 j. @
    ' G: ^4 q2 p1 v) |0 N0 |4 `. y! X( x4 S) v/ g- y5 Q/ s

    ) t9 S8 R6 H6 @" Z7 T" G1.2 最大流问题9 A, W; A* w! `  p
    考虑如下流网络 N = (V, A,U,D):节点 s 为网络中唯一的源点,t 为唯一的汇点, 而其它节点为转运点。如果网络中存在可行流 f ,此时称流 f 的流量(或流值,flow value)为 (根据(3),它自然也等于 −  ),通常记为v 或v( f ) ,即
    9 U: g1 Q$ P/ H# c' v8 ^- H+ E* V
    " `% W4 [1 k+ c" [- c0 Q; D$ j- d1 x* h8 z0 s( g2 p. v8 M: G8 K
    对这种单源单汇的网络,如果我们并不给定  和  (即流量不给定),则网络一 般记为 N = (s,t,V, A,U) 。最大流问题( maximum flow problem )就是在 N = (s,t,V, A,U) 中找到流值最大的可行流(即最大流)。我们将会看到,最大流问题 的许多算法也可以用来求解流量给定的网络中的可行流。也就是说,当我们解决了最大 流问题以后,对于在流量给定的网络中寻找可行流的问题,通常也就可以解决了。& m, y" W1 a4 h

    ( L& p6 g" ?3 q( B5 z3 r/ M4 B用线性规划描述最大流问题* P' {( U$ n1 ~' X) o
    因此,用线性规划的方法,最大流问题可以形式地描述如下:
    : R& F  ]0 [2 f2 M/ v) h# T% K- h+ o- }
    ; h# ^0 l* m( h+ P) R, `
    - N( Q$ J6 Z6 N3 ^8 U, O. p
    ) N: w. f3 C% ]: t3 `+ H. J定义】 如果一个矩阵 A 的任何子方阵的行列式的值都等于0,1或 −1,则称 A 是 全幺模的(totally unimodular TU,又译为全单位模的),或称 A 是全幺模矩阵。
    4 A5 z- z/ b1 V$ o5 M2 Z# w7 S" U6 D' Y  S3 T* I6 ~. @; z* X
    整流定理3 Q: o% z. F, S6 e
    【定理 7】(整流定理) 最大流问题所对应的约束矩阵是全幺模矩阵。若所有弧容量 均为正整数,则问题的最优解为整数解。 最大流问题是一个特殊的线性规划问题。我们将会看到利用图的特点,解决这个问 题的方法较之线性规划的一般方法要方便、直观得多。
    - G0 X$ \6 X7 N2 Q8 W2 W3 J* i# T; I4 ~0 ^' {8 |/ J' L2 W5 C6 ]
    1.3 单源和单汇运输网络( X$ W3 h2 A  b5 _- V
    多源多汇网络 转化成单源单汇网络# t4 m& G3 R2 a& f" J& e
    实际问题往往是多源多汇网络,为了计算的规格化,可将多源多汇网络G 化成单 源单汇网络G' 。设 X 是G 的源,Y 是G 的汇,具体转化方法如下:# w4 x7 j% ~* X) [) d7 Z6 m
    % n" S: ^" ^" o! T# }
    (i)在原图G 中增加两个新的顶点 x 和 y ,令为新图G' 中之单源和单汇,则G 中 所有顶点V 成为G' 之中间顶点集。
    6 _4 k  t) `+ J
    4 M  l1 ~1 V, M8 a2 g7 s: h- v) |(ii)用一条容量为∞的弧把 x 连接到 X 中的每个顶点。
    0 q# Y+ j0 [  }7 @+ y# _* p7 H1 q. I
    (iii)用一条容量为∞的弧把Y 中的每个顶点连接到 y 。 G 和G' 中的流以一个简单的方式相互对应。若 f 是G 中的流,则由
    9 T$ j. ?) R, [2 T6 x4 b* X2 N3 U) g6 _  I% \
    . ?* l2 r- M7 t8 |% o) h

    * e1 @7 f2 l6 \1 H% V2 最大流和最小割关系割的容量8 r& v  o) X. x$ P+ P0 q

    # Q" o* U/ ?& }3 \8 h# L/ @2 h' G; `0 `: O1 S
    3 U8 j% ]7 L% i% f
    则在这条可增广轨上每条前向弧的流都可以增加一个量δ ,而相应的后向弧的流可减 少δ ,这样就可使得网络的流量获得增加,同时可以使每条弧的流量不超过它的容量, 而且保持为正,也不影响其它弧的流量。总之,网络中 f 可增广轨的存在是有意义的, 因为这意味着 f 不是最大流。* A& m* w# E. d. ]

    : S1 ^& `; x, Q5 U5 ~% u: H8 g3 最大流的一种算法—标号法
    . i- l: j5 k7 q0 ~9 \" a! g2 ]7 C. s标号法是由 Ford 和 Fulkerson 在 1957 年提出的。用标号法寻求网络中最大流的基 本思想是寻找可增广轨,使网络的流量得到增加,直到最大为止。即首先给出一个初始 流,这样的流是存在的,例如零流。如果存在关于它的可增广轨,那么调整该轨上每条 弧上的流量,就可以得到新的流。对于新的流,如果仍存在可增广轨,则用同样的方法 使流的值增大,继续这个过程,直到网络中不存在关于新得到流的可增广轨为止,则该 流就是所求的最大流。
    4 i0 x$ d- R) Q
    7 @2 c, u' p, U! ^; Z) [. ~这种方法分为以下两个过程:; t: B5 s  a0 q0 ^$ h& E

    . f% H7 d8 C- F6 L4 vA.标号过程:通过标号过程寻找一条可增广轨。4 ^5 i% y0 k: L/ I" d2 j
    4 k# `6 a' `2 U( i7 {
    B.增流过程:沿着可增广轨增加网络的流量。% T) s6 R' V- y0 h
    4 v9 h1 s7 A5 E
    这两个过程的步骤分述如下。
    - `0 |- U" l/ f3 k- s
    4 V9 P  Q8 `" w(A)标号过程:- n1 t" Q/ o/ I2 ^* D
    ) T' _# l& \) ^
    7 }) B; G& F# Z% c3 n

    1 E( u, D  d; l! g4 g) R9 r(B)增流过程
    $ j( u% V# X5 Q
    4 i, B. @" G' N+ A& V+ }网络最大流 x 的求解步骤
    $ V% t6 P! E4 \) H. u" g4 d求网络 N = (s,t,V, A,U) 中的最大流 x 的算法的程序设计具体步骤如下:+ Y% `$ a5 W, u  A% g
    2 t2 F3 p6 c8 ~+ Z
    对每个节点 j ,其标号包括两部分信息 (pred( j),maxf(j))) ~4 F5 n! d  K! g8 P* U

    : ?& f* @1 r7 |6 i该节点在可能的增广路中的前一个节点 pred( j) ,以及沿该可能的增广路到该节点为止 可以增广的最大流量 maxf( j)。
    6 N, N; U" I" n8 [0 U2 b8 R4 k: [9 H

      [5 a7 k4 C' j3 M0 G9 U; M  F8 N  a! e1 X

    并将 j 加入 LIST 中。

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


    ) c" t! \( q1 M$ F/ {  D, V3 z5 p& _
    - ^( ]" e+ L: @' ?1 _9 c% P7 _# R% k* C2 M: b8 T% A, Q0 b' i; M
    解 编写程序如下:, t8 @6 \+ l% v) k; M) t* N
    / m5 P, @; A* }- t! l
    clc,clear7 B& x1 F$ _5 ?" ^& l) {  l
    u(1,2)=1;u(1,3)=1;u(1,4)=2;u(2,3)=1;u(2,5)=2;6 f! \9 J' [% |" ]  P& G
    u(3,5)=1;u(4,3)=3;u(4,5)=3;' y( y5 F- i3 Q2 D3 {! I
    f(1,2)=1;f(1,3)=0;f(1,4)=1;f(2,3)=0;f(2,5)=1;
    1 @9 u' _; A+ F: V0 K5 df(3,5)=1;f(4,3)=1;f(4,5)=0;: [# e( l7 x+ a' h  I% L2 K6 s
    n=length(u);list=[];maxf(n)=1;
    * c- y- @  R4 ~8 r; _5 o8 p; Cwhile maxf(n)>0. j- D; ~* N& w  c1 `
    maxf=zeros(1,n);pred=zeros(1,n);+ N: C% R' |; s( s
    list=1;record=list;maxf(1)=inf;: o  Z: o& _/ P% K
    % list是未检查邻接点的标号点,record是已标号点! X0 `0 W3 |; R, x& i2 H4 T
    while (~isempty(list))&(maxf(n)==0)7 Q; i" W2 Y& p5 q$ m$ y
        flag=list(1);list(1)=[];
    1 e% A1 V4 G9 Q3 |    label1= find(u(flag,-f(flag,);5 ]8 i5 [6 d, R" C  P% _
        label1=setdiff(label1,record);( b" [% a3 [( v1 E9 K( L7 x$ b
        list=union(list,label1);
    # M: \1 g5 w, c$ Z/ u: o    pred(label1)=flag;
    + g1 X3 T0 n% q) ?  D    maxf(label1)=min(maxf(flag),u(flag,label1)...
    1 Z( z! O- d. ~. R( {0 |    -f(flag,label1));+ @7 R8 w4 p4 q0 H. C+ `' G# o
        record=union(record,label1);" Z2 P% c* H. M) {$ B
        label2=find(f(:,flag));# f" u6 g  H* L* x
        label2=label2';5 a( L, V& P8 g- z& h
        label2=setdiff(label2,record);) F* g. Y! K* J( t7 j3 E4 N
        list=union(list,label2);5 j6 s/ g+ T. X& {& s
        pred(label2)=-flag;
    ! e8 n/ X0 p0 p1 g    maxf(label2)=min(maxf(flag),f(label2,flag));0 g$ K, x, {& Y& g- h6 P+ v
        record=union(record,label2);
    " v; `0 N' Z* R9 y end
    ( S4 C" d# [( L3 X     if maxf(n)>0* K5 Y& Q7 ^6 `) Z0 A
            v2=n; v1=pred(v2);
    . o! A1 l0 j0 b, O4 w. f- _        while v2~=16 M. {3 ]5 Z. e7 U4 D) j$ y
                if v1>0. B0 p2 B% Z" p! W  ]% |
                    f(v1,v2)=f(v1,v2)+maxf(n);) t/ Q' i. z6 `' H+ G' ]9 ?9 d! V
                else  X1 W2 E1 j( L( `# C
                    v1=abs(v1);/ R& w, m! g4 @' X* S/ o- o
                    f(v2,v1)=f(v2,v1)-maxf(n);
    " o9 x& X8 _% }6 {( }) {            end
    6 d. d4 E6 v0 A! M2 r( ^8 P7 D% H            v2=v1; v1=pred(v2);1 y, g! T7 p" Y$ R) X! E: u
            end
    8 n" I, s) W- x9 \    end9 R0 ^( i3 G% z' H  Y( [, {. P
    end
    + R$ d1 j$ B! x4 t# mf   ]0 x9 L8 H& |
    例18 现需要将城市 s 的石油通过管道运送到城市t ,中间有4个中转站  v1 ,v2 ,v3 和  v4 ,城市与中转站的连接以及管道的容量如图7所示,求从城市 s 到城市t 的最大流。& S" R+ ?) x; c: C! \0 g/ {0 k  B
    0 b/ J8 q/ m1 |) y! ?4 R

    3 M5 k% o/ ]1 Z: I, \+ o
    $ \; ?4 o: H% T6 n' D" X
      I5 @& S; h4 Y/ ~2 l解 使用最大流的数学规划表达式,编写LINGO程序如下:
    / b9 |. O  j+ S, R4 ^+ N0 k+ R- y% t* v: H: I: g
    model:
    2 b+ z' C0 A7 D  T3 ?7 t9 m. rsets:
    . l8 g; D* R) ]6 E4 ~6 g" qnodes/s,1,2,3,4,t/;$ U) c3 @  _4 y7 k' s
    arcs(nodes,nodes)/s 1,s 3,1 2,1 3,2 3,2 t,3 4,4 2,4 t/:c,f;
    " k* c2 t' c6 c7 nendsets
    ; Y0 P( a) S6 W2 W. m+ ydata:1 y) J' w5 m  ]$ b/ a
    c=8 7 9 5 2 5 9 6 10;
    4 i# i- h0 H# u- u( nenddata' g6 k4 V5 v; V( ^/ z- R7 ~
    n=@size(nodes); !顶点的个数;* S5 u( z" B$ l7 Q# ~
    max=flow;
    ! M" m" @- I$ S" R5 R. b@for(nodes(i)|i #ne#1 #and# i #ne# n:$ G4 N8 x. `( V/ h& b: c
        @sum(arcs(i,j):f(i,j))=@sum(arcs(j,i):f(j,i)
    - C3 I; A4 k$ J@sum(arcs(i,j)|i #eq# 1:f(i,j))=flow;
    - ^1 g9 Z, R0 @6 j% P; Z/ L( M@sum(arcs(i,j)|j #eq# n:f(i,j))=flow;6 p5 `' o; D; x# u6 g
    @for(arcsbnd(0,f,c));
    2 _" D9 D  L' D* D! B3 [end
    / w7 m* Q* n, {* `7 G. y
    * h, ]% P# m% \2 T  R3 _在上面的程序中,采用了稀疏集的编写方法。下面介绍的程序编写方法是利用赋权邻 接矩阵,这样可以不使用稀疏集的编写方法,更便于推广到复杂网络。2 A0 E" C" T; i, ^9 y
    ( W3 F" V" Z& V* f
    model:! Y; u5 [" _% e7 U# b( `3 c$ u0 M
    sets:1 T+ A$ j+ [3 W, }4 {
    nodes/s,1,2,3,4,t/;4 P" ^$ K5 }- P% v
    arcs(nodes,nodes):c,f;; v5 y+ n/ u$ _1 R/ U1 R8 F! v
    endsets
    % p  U% \2 {4 Z4 {' Q/ U/ c, sdata:- s$ s1 v; |( n0 n9 d
    c=0;
    # S" Y( x5 |6 u: t@text('fdata.txt')=f;' y0 c$ V& ~0 u
    enddata9 v2 P4 |8 n# l3 i  o* E
    calc:
    / Y7 s( G+ h" _; b9 \7 cc(1,2)=8;c(1,4)=7;7 I3 T) N0 t4 @$ a) v2 o
    c(2,3)=9;c(2,4)=5;! M% F4 }* }$ ^7 \' N- [' v7 v
    c(3,4)=2;c(3,6)=5;
    7 a3 n) d# Z, v5 Y+ d7 Q5 E) f0 @' jc(4,5)=9;c(5,3)=6;c(5,6)=10;8 G0 v( O9 K' T5 P% b
    endcalc' I% M  r7 \9 C+ Z$ q! G0 a4 b' I
    n=@size(nodes); !顶点的个数;
    & p% ?2 p5 e% D& V2 |( C6 U) Fmax=flow;9 d. r; I) q, m& h- G- L% G
    @for(nodes(i)|i #ne#1 #and# i #ne# n:
    6 K) h, s, w' p3 l/ ^    @sum(nodes(j):f(i,j))=@sum(nodes(j):f(j,i)));3 E. f& U0 |5 q2 O8 _# T5 L
    @sum(nodes(i):f(1,i))=flow;
    5 I3 ~9 Z  m0 P; K& o! F- V/ o  `2 K* B@sum(nodes(i):f(i,n))=flow;
    ' s! n9 z1 Z6 x  v  M* B@for(arcsbnd(0,f,c));0 y! l9 K7 Y/ n9 h
    end" K, u3 C5 {# g
    * N4 \0 g- v. T5 Z
    ————————————————
    $ V9 J/ u/ V" \5 o  ~% u0 v/ \+ ]2 @版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。8 ]' }0 g7 ~$ w" i$ j0 u) R
    原文链接:https://blog.csdn.net/qq_29831163/article/details/89786313( x% j  f. v  A/ c; Q. E+ P
    ) n3 M. F# c, S& V7 N
    " K' o$ D, @( B& H- P
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2025-8-20 14:13 , Processed in 0.394608 second(s), 50 queries .

    回顶部