QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1973|回复: 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 最大流问题的数学描述/ w( M; ?# }1 p! L
    1.1 网络中的流 定义9 [0 A' U) P$ K) Z/ f
    在以V 为节点集, A 为弧集的有向图G = (V, A) 上定义如下的权函数:9 N' K" Q% [; Y3 M9 y& h

    # t7 ^" r* j2 m1 {  s1 _  m! \(i) L : A → R 为孤上的权函数,弧 (i, j)∈ A 对应的权 L(i, j) 记为 ,称为孤 (i, j) 的容量下界(lower bound);
    & v9 B: f- h2 B' [1 q& k7 c0 [. [- C( F9 N8 t- l4 P  }. v
    (ii)U : A → R 为弧上的权函数,弧(i, j)∈ A对应的权U(i, j) 记为 ,称为孤 (i, j) 的容量上界或容量(capacity);
    + q4 Z, A, y+ }6 ?; N% G1 X4 {/ X; D9 }# ?: q
    (iii) D :V → R 为顶点上的权函数,节点i ∈V 对应的权 D(i) 记为  ,称为顶 点i 的供需量(supply/demand);
    4 p* f8 V. M; a% O9 B6 v9 x( O! z/ n
    此时所构成的网络称为流网络,可以记为 N = (V, A, L,U,D) 。 由于我们只讨论V, A 为有限集合的情况,所以对于弧上的权函数 L,U 和顶点上的 权函数 D ,可以直接用所有孤上对应的权和顶点上的权组成的有限维向量表示,因此 L,U, D 有时直接称为权向量,或简称权。由于给定有向图G = (V, A) 后,我们总是可 以在它的弧集合和顶点集合上定义各种权函数,所以流网络一般也直接简称为网络。
    ! {% I( h) R4 |& s  ]- ]5 n5 O
    / w0 j' T+ f5 U6 v/ ~. y% x在流网络中,弧(i, j) 的容量下界  和容量上界表示的物理意义分别是:通过该 弧发送某种“物质”时,必须发送的最小数量为 ,而发送的最大数量为 。顶点i ∈V 对应的供需量则表示该顶点从网络外部获得的“物质”数量( > 0时),或从该顶 点发送到网络外部的“物质”数量(< 0 时)。下面我们给出严格定义。3 f9 [, \; s0 I9 p, k$ R4 C  ]8 ?
    7 N; R" J+ h7 y3 a
    可行流(feasible flow)! G2 _, {- g- p1 @$ A
    " Q9 H& J5 J6 s1 {0 R. S  V0 D

    5 n/ ]' k. W% j$ u9 j  A- Y. b. N6 R' p- E6 t' U

    3 g: r. [% Q6 d6 i可见,当 di > 0时,表示有di 个单位的流量从网络外部流入该顶点,因此顶点i 称 为供应点(supply node)或源(source),有时也形象地称为起始点或发点等;当di < 0 时,表示有|di | 个单位的流量从该顶点流失到网络外部(或说被该顶点吸收),因此顶 点i 称为需求点(demand node)或汇(sink),有时也形象地称为终止点或收点等;当 di = 0时,顶点i 称为转运点(transshipment node)或平衡点、中间点等。此外,根据 (1)可知,对于可行网络,必有
    8 Z& Z& F- b0 B% n- t1 Z* Y! y, a% a% r  {* [' e

    ( y& i+ @, N" E* ]
    - k) G8 S5 D+ k9 _* N也就是说,所有节点上的供需量之和为 0 是网络中存在可行流的必要条件9 h% r- Q/ K4 n; p

    # M6 ?' I3 @4 f" V. n; W. i/ V
    9 `: n* r. P" I" M; ~: F+ a" @7 q
    0 R: O5 D( A9 _% ^  j/ F7 y2 a) V3 c! q9 s
    1.2 最大流问题- U# ^6 p1 z2 E. u/ |( B; r
    考虑如下流网络 N = (V, A,U,D):节点 s 为网络中唯一的源点,t 为唯一的汇点, 而其它节点为转运点。如果网络中存在可行流 f ,此时称流 f 的流量(或流值,flow value)为 (根据(3),它自然也等于 −  ),通常记为v 或v( f ) ,即% d; {/ v1 W: g8 ~6 `; w* v7 r! F# w
    & E1 t  a& Q$ h7 D, ^: ]

    $ p& |9 x5 ^5 e. s对这种单源单汇的网络,如果我们并不给定  和  (即流量不给定),则网络一 般记为 N = (s,t,V, A,U) 。最大流问题( maximum flow problem )就是在 N = (s,t,V, A,U) 中找到流值最大的可行流(即最大流)。我们将会看到,最大流问题 的许多算法也可以用来求解流量给定的网络中的可行流。也就是说,当我们解决了最大 流问题以后,对于在流量给定的网络中寻找可行流的问题,通常也就可以解决了。( O1 w8 s9 `# b8 N/ I3 `
    0 \1 @: d3 c& k+ D, n+ `
    用线性规划描述最大流问题: K- ?3 R1 \# m2 v! o" ^+ T# W
    因此,用线性规划的方法,最大流问题可以形式地描述如下:
    1 v3 Q1 j+ Z. R3 C8 ?" s" Q0 P' z1 A3 `5 ~+ p" L' A

    . q* \- g" B& _; b+ {4 p$ }2 q& t5 F9 O1 x3 w! B; g) o" ]8 c
    定义】 如果一个矩阵 A 的任何子方阵的行列式的值都等于0,1或 −1,则称 A 是 全幺模的(totally unimodular TU,又译为全单位模的),或称 A 是全幺模矩阵。6 S1 e: |0 i* {$ a2 v

    ) ~4 Y2 M  L  U$ ^整流定理
    ) E8 f9 i- D3 N; ^6 P【定理 7】(整流定理) 最大流问题所对应的约束矩阵是全幺模矩阵。若所有弧容量 均为正整数,则问题的最优解为整数解。 最大流问题是一个特殊的线性规划问题。我们将会看到利用图的特点,解决这个问 题的方法较之线性规划的一般方法要方便、直观得多。% S, {8 D6 A3 K0 j' C! F

    1 J5 T6 m: a- Q0 F: {1.3 单源和单汇运输网络
    % a! B! q$ S5 ~$ S1 R$ D) Z8 ~多源多汇网络 转化成单源单汇网络
    : G2 ?) G4 Q0 u: m0 U实际问题往往是多源多汇网络,为了计算的规格化,可将多源多汇网络G 化成单 源单汇网络G' 。设 X 是G 的源,Y 是G 的汇,具体转化方法如下:& c3 f5 s# |8 r9 b
    2 a1 _6 S( O2 T6 }5 G+ s
    (i)在原图G 中增加两个新的顶点 x 和 y ,令为新图G' 中之单源和单汇,则G 中 所有顶点V 成为G' 之中间顶点集。
    ( r" S9 U: F2 h( N& c" e1 c
    * h7 k  J9 p; ?' y(ii)用一条容量为∞的弧把 x 连接到 X 中的每个顶点。& e3 t, J5 b1 i/ E) m5 y( h

    1 l( f5 F- o1 F- p0 m  H6 U(iii)用一条容量为∞的弧把Y 中的每个顶点连接到 y 。 G 和G' 中的流以一个简单的方式相互对应。若 f 是G 中的流,则由
    1 |0 A5 w* K6 r$ v, m9 Z. b! ^, l9 X3 ]! W

    , }: |# e! O. |1 O! ^7 F5 z0 W! s: u' O. h: c
    2 最大流和最小割关系割的容量
    / w8 ?3 d% v9 t2 O. V8 I, c9 j* N. Q$ |) w% O  N
    + [* b  u$ @0 \) y4 ]9 x  c
    6 e& ^9 q: C/ A$ Q/ K6 Q* D
    则在这条可增广轨上每条前向弧的流都可以增加一个量δ ,而相应的后向弧的流可减 少δ ,这样就可使得网络的流量获得增加,同时可以使每条弧的流量不超过它的容量, 而且保持为正,也不影响其它弧的流量。总之,网络中 f 可增广轨的存在是有意义的, 因为这意味着 f 不是最大流。; v' c2 a4 B1 l9 H% l) e8 Q
    1 c* H- j' J! T8 z
    3 最大流的一种算法—标号法
    + g2 u% }1 {3 d7 D, a8 G标号法是由 Ford 和 Fulkerson 在 1957 年提出的。用标号法寻求网络中最大流的基 本思想是寻找可增广轨,使网络的流量得到增加,直到最大为止。即首先给出一个初始 流,这样的流是存在的,例如零流。如果存在关于它的可增广轨,那么调整该轨上每条 弧上的流量,就可以得到新的流。对于新的流,如果仍存在可增广轨,则用同样的方法 使流的值增大,继续这个过程,直到网络中不存在关于新得到流的可增广轨为止,则该 流就是所求的最大流。
    " v& ^' d- p) u$ f/ \
    " }, A$ H7 R, D) y  y& f0 f9 B/ j这种方法分为以下两个过程:& f, d, Y3 B3 Y& h
    $ g4 b+ C: L6 a/ i8 }" Q6 f
    A.标号过程:通过标号过程寻找一条可增广轨。
    1 m2 Z% k5 a4 z5 U  j. Y2 ^% ?  w9 A# X4 g/ \' W
    B.增流过程:沿着可增广轨增加网络的流量。
    , }; F  E/ j  k* {- g) m5 B+ \- M/ t: B9 y9 o; K3 l) Z
    这两个过程的步骤分述如下。! o7 C6 n, P+ c2 ]1 z# P% ?) u. H

    1 J/ {) K& J# Q! s3 {2 c; F(A)标号过程:& D0 b- y3 e* ]) C; J. G1 N) f4 J% i

    + B0 t: M2 F- T1 e( X7 e
    $ z- [$ `! L' d$ |# E2 _- W% ^2 O3 S6 X; S3 n
    (B)增流过程
    ! M+ D% g( Q/ \8 M
    : r# Y; r0 C8 A* x  D- E网络最大流 x 的求解步骤9 q3 n8 b" t9 j! |9 `. t# _
    求网络 N = (s,t,V, A,U) 中的最大流 x 的算法的程序设计具体步骤如下:
    ) X1 D' @% J' S, f
    2 ^/ Y" y$ Z8 t& q4 M对每个节点 j ,其标号包括两部分信息 (pred( j),maxf(j))
    4 }- ~! u- ~: C) E9 w$ ~% Q' I! Z
    该节点在可能的增广路中的前一个节点 pred( j) ,以及沿该可能的增广路到该节点为止 可以增广的最大流量 maxf( j)。9 ~' Y1 K3 M6 I; ~9 |: v2 T$ z3 n5 R' d
    ; u* }# J* i6 p) T) j% ]4 B0 j

    2 W' k% P. z5 j1 q: a" ~: Z
    " v: d7 a3 z. c- y

    并将 j 加入 LIST 中。

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

    7 O% L. _2 c( g1 x! N

    / c! |1 B" x2 z3 P" G" c: f
    / C/ y2 \+ U- m5 E  x解 编写程序如下:; {# K2 i; _; Z
    6 Y) n' R3 z& Q; S; W
    clc,clear: a6 b) h4 I3 W7 J& P/ g+ \
    u(1,2)=1;u(1,3)=1;u(1,4)=2;u(2,3)=1;u(2,5)=2;
    / Y4 a. G9 D% l0 U7 r" R7 ]. h0 s3 M. ju(3,5)=1;u(4,3)=3;u(4,5)=3;: V6 @5 v3 o4 }/ Y3 N) _& v
    f(1,2)=1;f(1,3)=0;f(1,4)=1;f(2,3)=0;f(2,5)=1;
    6 T: }( ]5 F+ u0 sf(3,5)=1;f(4,3)=1;f(4,5)=0;, @5 R% P. m1 N: @. t% O" L* F
    n=length(u);list=[];maxf(n)=1;4 m7 t* \4 f- i
    while maxf(n)>0
    5 G+ l4 M' \, Q9 Fmaxf=zeros(1,n);pred=zeros(1,n);" H" ^; Q$ Z4 n* q$ X8 S7 t
    list=1;record=list;maxf(1)=inf;
    . e' n( {) [( I2 A2 \- C % list是未检查邻接点的标号点,record是已标号点6 I/ O+ ?+ \0 R2 [: D
    while (~isempty(list))&(maxf(n)==0)
    - I2 V! v/ C9 _    flag=list(1);list(1)=[];
    0 k8 C  `8 }+ _0 R% D" r    label1= find(u(flag,-f(flag,);
    # j% f2 S; N  P) ^) M0 E. }/ h6 [    label1=setdiff(label1,record);
    - R3 y/ N7 ]% Z% c4 }" W" }    list=union(list,label1);5 b- e& t# d8 E- j! o
        pred(label1)=flag;+ b* i4 i$ E( z
        maxf(label1)=min(maxf(flag),u(flag,label1)...
    6 t, h' U- P5 U9 R9 q    -f(flag,label1));. {* D1 f7 |* ^: ], g
        record=union(record,label1);. t0 z  C: h6 x- }
        label2=find(f(:,flag));* g  S7 S0 z0 i. Z) k2 @
        label2=label2';0 L# l/ s; e4 x2 P& O) k$ ~% c
        label2=setdiff(label2,record);* H4 d- X3 b2 [  t2 Q- u
        list=union(list,label2);
    9 a  N. f: H; A3 K' X: s    pred(label2)=-flag;/ X; S9 B# a% _5 R( u5 F7 v- r4 }
        maxf(label2)=min(maxf(flag),f(label2,flag));7 ^* C  N0 N; m2 g' ]
        record=union(record,label2);
    2 o7 d7 n- u+ R5 n+ t9 S end" S# b; ^8 k" i
         if maxf(n)>0
    5 Y2 C2 M% D5 e4 Z7 Z        v2=n; v1=pred(v2);
    3 W' ?$ q7 ?1 j; i1 ]        while v2~=1
    ; M5 V$ h. U9 H            if v1>0
      L1 {& ]+ j; Q3 z& v0 Q                f(v1,v2)=f(v1,v2)+maxf(n);# j1 Z2 _1 T- |' h7 T1 V
                else' F* \# m2 R2 S7 G
                    v1=abs(v1);* T2 `- `5 L* s6 U1 \! \% T5 d
                    f(v2,v1)=f(v2,v1)-maxf(n);+ h& |+ h2 h3 K- P6 d: `1 \  m
                end% B  j  W' n& [) U
                v2=v1; v1=pred(v2);
    7 E# l7 I8 \1 c6 I; a+ }        end
    ' c0 e$ q% R8 q5 Y3 _    end
    * n" F: R7 }* Q" Rend8 ^2 M  ]) D/ X9 G% |! J
    f 3 K" L! m) a- t( V) M
    例18 现需要将城市 s 的石油通过管道运送到城市t ,中间有4个中转站  v1 ,v2 ,v3 和  v4 ,城市与中转站的连接以及管道的容量如图7所示,求从城市 s 到城市t 的最大流。* X+ `* o  G7 P2 X# z

    9 d5 }. c  D1 E9 V
    2 ?6 b! S9 Q- |: M. g, ^- B: D2 a( |- a; x! a2 g+ l3 E
    3 M# w& ~4 e6 Q$ t5 D7 i3 l
    解 使用最大流的数学规划表达式,编写LINGO程序如下:
    : \& P9 H0 n/ q% k0 E# |. a0 S2 {
    : h4 D+ N( R# U. Z7 W/ P5 ^' Rmodel:
    % K  p- u3 V, \: C9 K) q6 Isets:* O; H4 d0 b5 i6 j1 q, N9 P" Y
    nodes/s,1,2,3,4,t/;
    3 w' }/ J* W; k9 Varcs(nodes,nodes)/s 1,s 3,1 2,1 3,2 3,2 t,3 4,4 2,4 t/:c,f;8 Q5 e+ p8 e1 X
    endsets
    % O# ~, n! u; `% S* _4 b9 Fdata:
    * D9 B1 y' c# j- Jc=8 7 9 5 2 5 9 6 10;+ O8 a# g! i8 S" i8 J6 Y
    enddata% ]8 \. z5 y9 w4 d9 S) `* w) q) _9 g
    n=@size(nodes); !顶点的个数;2 ^8 @6 w* e5 o$ I" p
    max=flow;
    $ _. }! o; R( Z7 A, O; I@for(nodes(i)|i #ne#1 #and# i #ne# n:
    " g" g+ H& o$ S2 e' w6 c+ B    @sum(arcs(i,j):f(i,j))=@sum(arcs(j,i):f(j,i)
    # l8 w8 M, k9 {# w4 Q@sum(arcs(i,j)|i #eq# 1:f(i,j))=flow;5 ]2 j  x' M2 V& c# w* F& {# }; H
    @sum(arcs(i,j)|j #eq# n:f(i,j))=flow;
    ) L5 W& E* Q8 W; f@for(arcsbnd(0,f,c));
    ) g9 R( H3 D8 o5 d( |5 M' [7 ^3 J# mend 8 O  J% E0 U/ S4 D7 `+ m

    3 m. v8 x; B) G! w在上面的程序中,采用了稀疏集的编写方法。下面介绍的程序编写方法是利用赋权邻 接矩阵,这样可以不使用稀疏集的编写方法,更便于推广到复杂网络。
    % h$ @" A% u. X& V% f( P) X/ |$ [: c! m$ V) j: D% `
    model:! w) p5 @, H  f+ I8 R
    sets:4 _2 ?& A9 y/ i3 _; [- ~- N6 G
    nodes/s,1,2,3,4,t/;8 }' s: V0 e, F& q1 b
    arcs(nodes,nodes):c,f;, o3 F. B% a* H
    endsets/ o8 J4 h6 I7 u( d
    data:2 @2 {7 i/ n, F
    c=0;
    2 M3 ^$ w* W0 Y/ _, e@text('fdata.txt')=f;4 t. y! \$ r+ x3 s( v+ H6 e
    enddata
    7 `0 B; |" \) S% ?calc:
    - P0 O$ V& ^, V' zc(1,2)=8;c(1,4)=7;* n" N) H" ~* T0 ^8 ^
    c(2,3)=9;c(2,4)=5;6 M3 d* n' k# O, }: q
    c(3,4)=2;c(3,6)=5;" a2 P& t$ ?& M& Q
    c(4,5)=9;c(5,3)=6;c(5,6)=10;) U# R2 ]( p; P5 v0 q4 l
    endcalc
    2 b: ]" T! |9 g& Q  Kn=@size(nodes); !顶点的个数;
    : @6 z8 W0 k# [6 qmax=flow;4 V6 H8 G9 `! `" m3 k
    @for(nodes(i)|i #ne#1 #and# i #ne# n:! }, y  z( H+ W! z: q
        @sum(nodes(j):f(i,j))=@sum(nodes(j):f(j,i)));2 c- G1 K, X, o/ x/ q3 g
    @sum(nodes(i):f(1,i))=flow;2 q5 J4 D% C, V4 f
    @sum(nodes(i):f(i,n))=flow;
    % {( Q7 u0 d" e* H+ ?@for(arcsbnd(0,f,c));
    # `9 k; V' n  b0 v2 Rend; m6 E8 Z( L2 G! v+ A# \
    ! ?0 |" z0 p7 s
    ————————————————
    8 `3 M$ I. ]" F( ?  t版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。" z# d' l8 r; {9 @
    原文链接:https://blog.csdn.net/qq_29831163/article/details/89786313" K3 ]; G( _3 ]5 p9 M0 Y

    7 i! a  R* ?: V1 p
    % z& ?7 w4 S0 |6 c" Y  G- ]+ W
    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, 2026-6-10 06:04 , Processed in 0.388464 second(s), 51 queries .

    回顶部