QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1943|回复: 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 最大流问题的数学描述
    % E7 m# |! L! x1.1 网络中的流 定义4 c8 f( z  C4 ~9 }. C% ^9 Y
    在以V 为节点集, A 为弧集的有向图G = (V, A) 上定义如下的权函数:. W6 D$ D) p9 @6 }3 q
    4 X1 O$ G5 W( t" k
    (i) L : A → R 为孤上的权函数,弧 (i, j)∈ A 对应的权 L(i, j) 记为 ,称为孤 (i, j) 的容量下界(lower bound);
    6 f) u; F$ o2 P$ {7 o4 K
    8 u/ D6 E' T# J: @/ T(ii)U : A → R 为弧上的权函数,弧(i, j)∈ A对应的权U(i, j) 记为 ,称为孤 (i, j) 的容量上界或容量(capacity);- O& Q* f6 H- m$ P' u; i
    1 Y7 N3 l" ]! O; [
    (iii) D :V → R 为顶点上的权函数,节点i ∈V 对应的权 D(i) 记为  ,称为顶 点i 的供需量(supply/demand);
    8 m. p+ ]2 |; W1 R0 I+ ~
    * u* W/ |9 h5 t+ [此时所构成的网络称为流网络,可以记为 N = (V, A, L,U,D) 。 由于我们只讨论V, A 为有限集合的情况,所以对于弧上的权函数 L,U 和顶点上的 权函数 D ,可以直接用所有孤上对应的权和顶点上的权组成的有限维向量表示,因此 L,U, D 有时直接称为权向量,或简称权。由于给定有向图G = (V, A) 后,我们总是可 以在它的弧集合和顶点集合上定义各种权函数,所以流网络一般也直接简称为网络。5 `, J0 q: H& U7 x3 N" }) W

    1 U+ y- I* k1 ~$ `0 P- M在流网络中,弧(i, j) 的容量下界  和容量上界表示的物理意义分别是:通过该 弧发送某种“物质”时,必须发送的最小数量为 ,而发送的最大数量为 。顶点i ∈V 对应的供需量则表示该顶点从网络外部获得的“物质”数量( > 0时),或从该顶 点发送到网络外部的“物质”数量(< 0 时)。下面我们给出严格定义。
    6 ~8 w9 [0 k1 j4 A: j7 R5 t$ v; b& O9 q- N' W2 F  O" U) |; |$ z  i
    可行流(feasible flow)$ y1 G$ _- T! a) D- r1 I

    6 N. y  b3 j0 S# M9 f& W5 n5 J6 {' y: u# x' i7 K
    5 \% `$ ]4 X; @* R

    - f! {0 A3 f4 c: w( m可见,当 di > 0时,表示有di 个单位的流量从网络外部流入该顶点,因此顶点i 称 为供应点(supply node)或源(source),有时也形象地称为起始点或发点等;当di < 0 时,表示有|di | 个单位的流量从该顶点流失到网络外部(或说被该顶点吸收),因此顶 点i 称为需求点(demand node)或汇(sink),有时也形象地称为终止点或收点等;当 di = 0时,顶点i 称为转运点(transshipment node)或平衡点、中间点等。此外,根据 (1)可知,对于可行网络,必有
    4 L4 G" o3 _' b3 ]0 Y  Z. U2 |1 t7 K/ x1 a$ R2 |/ y4 a
    6 f! }7 @4 D0 Z* l& j* }+ ]( Q7 H

    # u$ {* E' W5 w3 T5 S9 X- ?也就是说,所有节点上的供需量之和为 0 是网络中存在可行流的必要条件
    2 L2 s7 g3 u8 E- p0 q8 C+ G+ H# l3 n  A5 }2 ?6 }* r  w+ S
    2 `1 w, s- M& g9 \* m
    ; h  s8 p  \( a! T1 L

    : E) H+ W8 c$ l% T1 a! m1 P1.2 最大流问题
    & j: J- E1 H# @6 |* @' B: R# ~* p考虑如下流网络 N = (V, A,U,D):节点 s 为网络中唯一的源点,t 为唯一的汇点, 而其它节点为转运点。如果网络中存在可行流 f ,此时称流 f 的流量(或流值,flow value)为 (根据(3),它自然也等于 −  ),通常记为v 或v( f ) ,即
    2 E! C2 F! K& |( \+ {4 A8 \: w
    " @% m, c9 E! Z1 M4 K# S
    对这种单源单汇的网络,如果我们并不给定  和  (即流量不给定),则网络一 般记为 N = (s,t,V, A,U) 。最大流问题( maximum flow problem )就是在 N = (s,t,V, A,U) 中找到流值最大的可行流(即最大流)。我们将会看到,最大流问题 的许多算法也可以用来求解流量给定的网络中的可行流。也就是说,当我们解决了最大 流问题以后,对于在流量给定的网络中寻找可行流的问题,通常也就可以解决了。
    . M+ L* ^' y# R6 D1 Z+ N
    & Z7 z! a* A% x+ e& M; m9 j用线性规划描述最大流问题2 y+ i% v0 _$ }4 E( y
    因此,用线性规划的方法,最大流问题可以形式地描述如下:: Y  D- o4 @& A+ k" a
    ! B# \1 f- e2 j5 o
    9 J$ v5 l' ]9 s5 R1 o

    " [2 t1 L/ k% l2 r3 N1 O定义】 如果一个矩阵 A 的任何子方阵的行列式的值都等于0,1或 −1,则称 A 是 全幺模的(totally unimodular TU,又译为全单位模的),或称 A 是全幺模矩阵。
    " U4 r- w0 u% G3 A# |) ~3 k& F, E: f$ ]1 S: _
    整流定理
    5 `0 |+ q: n. m【定理 7】(整流定理) 最大流问题所对应的约束矩阵是全幺模矩阵。若所有弧容量 均为正整数,则问题的最优解为整数解。 最大流问题是一个特殊的线性规划问题。我们将会看到利用图的特点,解决这个问 题的方法较之线性规划的一般方法要方便、直观得多。
    - Q1 k; d" U" T& `, s+ Z1 m# U3 D& A' m
    1.3 单源和单汇运输网络* a: C0 t+ Z/ L1 p& }% [! |+ o) s
    多源多汇网络 转化成单源单汇网络
    4 C0 @7 l2 J) k2 u实际问题往往是多源多汇网络,为了计算的规格化,可将多源多汇网络G 化成单 源单汇网络G' 。设 X 是G 的源,Y 是G 的汇,具体转化方法如下:
    , z9 D: E7 _# R( n8 Q: M+ j9 |
    " _8 [' o, q2 K  b1 w+ Q0 O(i)在原图G 中增加两个新的顶点 x 和 y ,令为新图G' 中之单源和单汇,则G 中 所有顶点V 成为G' 之中间顶点集。5 K6 i4 G% v& Q" P8 I
    5 O5 G; _0 o3 R# z
    (ii)用一条容量为∞的弧把 x 连接到 X 中的每个顶点。* S8 E& E0 Y( U

    0 |$ W' |9 h; f% _$ M, m4 k5 f(iii)用一条容量为∞的弧把Y 中的每个顶点连接到 y 。 G 和G' 中的流以一个简单的方式相互对应。若 f 是G 中的流,则由2 _$ l0 v2 K$ G4 \( H
    # N) `6 f6 r2 N8 \
    $ C+ z" q: h2 q9 B1 l

    " a0 L# P# T6 K0 {, U2 c' o2 最大流和最小割关系割的容量  T: A, C5 ]: S

    - E& O7 }7 s  _# h+ H2 |$ |6 Q
      u4 N* u( K; l
    2 s' V  K$ W2 ?( {; A- E4 R则在这条可增广轨上每条前向弧的流都可以增加一个量δ ,而相应的后向弧的流可减 少δ ,这样就可使得网络的流量获得增加,同时可以使每条弧的流量不超过它的容量, 而且保持为正,也不影响其它弧的流量。总之,网络中 f 可增广轨的存在是有意义的, 因为这意味着 f 不是最大流。
    . a  v) r: m% D6 [4 f. e! K
    + A' H9 _) M0 f- K8 X+ G3 最大流的一种算法—标号法
    $ b8 O: Y4 W( g+ z* S标号法是由 Ford 和 Fulkerson 在 1957 年提出的。用标号法寻求网络中最大流的基 本思想是寻找可增广轨,使网络的流量得到增加,直到最大为止。即首先给出一个初始 流,这样的流是存在的,例如零流。如果存在关于它的可增广轨,那么调整该轨上每条 弧上的流量,就可以得到新的流。对于新的流,如果仍存在可增广轨,则用同样的方法 使流的值增大,继续这个过程,直到网络中不存在关于新得到流的可增广轨为止,则该 流就是所求的最大流。1 K6 t4 A9 b" V9 y8 o8 U& W
    ; L, f8 o' d! }: s* A) @
    这种方法分为以下两个过程:
    3 q7 {3 m5 H# q* b- S7 M
    4 d. ~7 Y5 R% a6 TA.标号过程:通过标号过程寻找一条可增广轨。4 d4 h' f* m7 o7 t) a5 O6 r1 v

    ( h; O# ^/ K0 g4 G- pB.增流过程:沿着可增广轨增加网络的流量。
    & W9 A) ^' g0 \) j
    ' o! w, e9 I  N; E7 A% {, P这两个过程的步骤分述如下。# t0 I& k) c9 K4 T, W! N

    2 m! S4 S/ H& p) X(A)标号过程:' q( O& \+ g- X% W+ O; c7 p

    : W. V0 V! A; T1 {3 e! Q' |
    % t, ~% B6 n) b+ Z! H% y/ d: {4 F9 S' j/ z+ _. h$ M
    (B)增流过程( d( ^* O  V/ c) _6 i
    0 e  y+ }- q" Y3 W) a& m
    网络最大流 x 的求解步骤1 r$ C+ r" |( N2 G; f. ?
    求网络 N = (s,t,V, A,U) 中的最大流 x 的算法的程序设计具体步骤如下:5 Q6 b, d/ J6 E* j+ i
    " N) t+ p5 M& N  o
    对每个节点 j ,其标号包括两部分信息 (pred( j),maxf(j))
    4 b1 D% M6 a) ]; F. {8 W
    $ f! D9 s( [* x' L该节点在可能的增广路中的前一个节点 pred( j) ,以及沿该可能的增广路到该节点为止 可以增广的最大流量 maxf( j)。  C0 `, C; }! o: P; q1 V

    - ?$ F+ N0 ~# }9 h4 q7 I, e0 P8 y: L; Z: x
    $ K6 l; m. v! U9 H: W. J

    并将 j 加入 LIST 中。

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


    , i4 G2 M4 {6 {/ A' X  n
    ! d$ }: E- q- N
    8 x7 _0 }/ d: D/ M解 编写程序如下:
    2 R* F5 W# ^4 b9 W- {8 g  k
      c4 c4 ]! I% M8 W. a  c. F+ j6 ?clc,clear
    6 l0 [7 Z! @; ru(1,2)=1;u(1,3)=1;u(1,4)=2;u(2,3)=1;u(2,5)=2;
    1 M1 r/ U1 A7 F& o. @! l! wu(3,5)=1;u(4,3)=3;u(4,5)=3;# Q1 M! d/ d$ [# a2 v7 |6 ~6 k6 H
    f(1,2)=1;f(1,3)=0;f(1,4)=1;f(2,3)=0;f(2,5)=1;
    " c! W4 j( m2 r) L: A4 t6 ?0 B, qf(3,5)=1;f(4,3)=1;f(4,5)=0;
    + m8 m/ q# L; L  \, A# Tn=length(u);list=[];maxf(n)=1;
    " t: N& e  l4 M6 L2 y$ i# f2 mwhile maxf(n)>0
    0 S. E/ z8 L* [$ ^* p; T/ Amaxf=zeros(1,n);pred=zeros(1,n);- l4 \, D- {2 V; P8 o. O
    list=1;record=list;maxf(1)=inf;
    ' {3 U, P' ~* c3 f % list是未检查邻接点的标号点,record是已标号点
    : ]  Y% e" _9 {. p2 _1 {- s( hwhile (~isempty(list))&(maxf(n)==0)
    8 l$ ]7 U2 a! V* `6 p* {6 p3 A1 K    flag=list(1);list(1)=[];5 r8 k2 R$ Y4 h6 N( O! p
        label1= find(u(flag,-f(flag,);+ V9 Z9 C. \; c' A4 I+ w, z
        label1=setdiff(label1,record);0 t+ l1 T8 ]. p2 L2 t9 V( ^& e. S
        list=union(list,label1);+ L, D3 k$ W9 `) n
        pred(label1)=flag;  ], |& I, _% m  X+ T7 ~/ ~& D
        maxf(label1)=min(maxf(flag),u(flag,label1)...
    9 N: O% j% n& h+ _7 t! Q    -f(flag,label1));$ C$ k: E$ J* O# F- U7 l' A
        record=union(record,label1);
    ' `# q( k, t4 Q    label2=find(f(:,flag));
    7 J* d9 A& z1 r. Y0 c0 i- M    label2=label2';
    : M: R5 g  R: a* x3 d, P    label2=setdiff(label2,record);+ d7 g& T/ h5 d& h2 t- Q
        list=union(list,label2);
    1 j3 h) w( |7 y/ S; A5 {    pred(label2)=-flag;/ ?% ]% D5 J( |  ^: J" a: d
        maxf(label2)=min(maxf(flag),f(label2,flag));
    8 E4 d+ c/ E$ r# k    record=union(record,label2);
    ( j8 a% L" b0 k& _5 b end
    / R+ u, D6 C0 k# {/ y7 h  n2 N     if maxf(n)>0# Z! y/ Q+ u) d- C5 k
            v2=n; v1=pred(v2);
    0 r* v: |" M) O! g, s        while v2~=1/ M4 d( e7 J3 t7 e1 E+ e  C
                if v1>0( Z, H, z4 c) l9 E. x  q8 C
                    f(v1,v2)=f(v1,v2)+maxf(n);' z  @7 @3 k3 }- j+ ~
                else
    : F' o; t. b9 o, `! p: D0 b                v1=abs(v1);
    * G2 e4 u/ u+ b* A6 j                f(v2,v1)=f(v2,v1)-maxf(n);% u& Z# S( k7 e- W0 }+ c
                end' P+ N/ Q) n4 ?
                v2=v1; v1=pred(v2);
    ) T3 Z2 O: U* g- {+ x        end
    $ B4 `6 W/ u5 d. h) Q    end
    # G( h: H; M5 [5 [* X% P' Send; o: a8 U2 A) {- ~  }
    f - k* T+ n2 I0 d  c
    例18 现需要将城市 s 的石油通过管道运送到城市t ,中间有4个中转站  v1 ,v2 ,v3 和  v4 ,城市与中转站的连接以及管道的容量如图7所示,求从城市 s 到城市t 的最大流。
    $ P' f3 ~8 t6 S
    , ^7 y, }# V) C0 h" y0 A- o& [  S
    9 k- E5 v6 r( p4 F4 {1 P/ t
    1 n6 K4 D* b% X+ y% h$ y, p1 y  I5 E9 X" [# ]) U7 M
    解 使用最大流的数学规划表达式,编写LINGO程序如下:
    ! }. I, m" P$ P1 [' o8 L+ u/ }  o# h7 k6 h# e
    model:
    * p& y! p# Z# R1 v4 [sets:" e; @0 [( P7 O
    nodes/s,1,2,3,4,t/;3 C# M9 U% z  r0 ?( Y
    arcs(nodes,nodes)/s 1,s 3,1 2,1 3,2 3,2 t,3 4,4 2,4 t/:c,f;& Y! p$ v8 ]+ d9 O$ c
    endsets3 F3 k3 {2 g. O% _1 A: ]& H/ G4 `
    data:
    " o& Y; @! V# T: @c=8 7 9 5 2 5 9 6 10;$ z7 e# W6 p  H1 N. l/ R0 d, y- D
    enddata
    ; R# q- B+ x9 ~: xn=@size(nodes); !顶点的个数;, u" r. @3 g& g
    max=flow;
    , f) d& s6 V" H% u" A& b@for(nodes(i)|i #ne#1 #and# i #ne# n:
    ) @4 t' K+ Z+ L& _1 ?; E    @sum(arcs(i,j):f(i,j))=@sum(arcs(j,i):f(j,i)
    ! z  x4 W: R. p; i# K9 F' }@sum(arcs(i,j)|i #eq# 1:f(i,j))=flow;8 s7 \* r8 `8 }& C$ O) \
    @sum(arcs(i,j)|j #eq# n:f(i,j))=flow;: K- ~! q' U! h2 \  u$ M
    @for(arcsbnd(0,f,c));
    * N3 |1 k2 L5 p& v9 i8 ^, [end * L/ d* o8 N/ Y$ Z  `

    - U% H$ ~5 v3 k& r* e在上面的程序中,采用了稀疏集的编写方法。下面介绍的程序编写方法是利用赋权邻 接矩阵,这样可以不使用稀疏集的编写方法,更便于推广到复杂网络。+ Q) e. G# r' ]+ U! e. G2 d; R7 `
    ) j) q. Z1 m5 D! H" \, w6 a6 n
    model:
    % s% }. F& X  C! Dsets:& L# N+ ~% M# G% N' G/ H: w
    nodes/s,1,2,3,4,t/;2 ?! y5 }% t, J" j& E9 _7 \( M
    arcs(nodes,nodes):c,f;" d- ]9 u* \9 L# z) S3 m* D  y
    endsets  E7 m% S8 S$ Q9 P/ q7 x
    data:
    6 W1 y7 G' ~; J0 ~% `c=0;% N. p) \8 N: Q3 O- _0 U
    @text('fdata.txt')=f;" ^7 \3 \9 q& K  c
    enddata4 r$ z% P, i5 D- b7 s8 ]6 [
    calc:
    / y2 e3 a  _3 ]9 |, J7 }* bc(1,2)=8;c(1,4)=7;! K' d: D- T4 z: p) _* N2 C
    c(2,3)=9;c(2,4)=5;2 K' Q- A2 n, @/ ~0 N6 O5 x
    c(3,4)=2;c(3,6)=5;1 e% Z7 |+ D4 M. ~7 ^; D# E
    c(4,5)=9;c(5,3)=6;c(5,6)=10;$ Z$ c* Y- y& f# k
    endcalc
      G3 q* j: I' Nn=@size(nodes); !顶点的个数;7 L, D9 S( H% N" z) P- k  e
    max=flow;7 Q" Q, v5 V! a) O( Z9 Z6 Y  p% A: g
    @for(nodes(i)|i #ne#1 #and# i #ne# n:
    / I0 C- }$ w* p- y$ H; O    @sum(nodes(j):f(i,j))=@sum(nodes(j):f(j,i)));' }9 b. L1 t& [  `4 Z* Q4 E' ?5 r2 s
    @sum(nodes(i):f(1,i))=flow;& h4 {/ J5 f% @2 ~  q
    @sum(nodes(i):f(i,n))=flow;
    / X1 x) L0 j/ `+ F8 E@for(arcsbnd(0,f,c));
    ) u8 G, K$ M7 X0 y- U/ r7 Lend3 a: W8 |% i0 h

    " s# r- j" N# w————————————————
    8 D4 ~- u% W; b" K, d版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。: H5 K( ]! G7 X! k  G
    原文链接:https://blog.csdn.net/qq_29831163/article/details/89786313& V5 w: o; L- h( C1 \" M

    % P1 i; H" V, ~( J( t4 S  X
    # ?* o5 `8 V' w, a4 d! Q+ c, b
    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-4-20 19:10 , Processed in 0.564487 second(s), 51 queries .

    回顶部