QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1813|回复: 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 最大流问题的数学描述( ^, p) D' t! `0 L7 i2 S/ `
    1.1 网络中的流 定义
    $ [% |' o. B$ ~% X) R& \# u' C在以V 为节点集, A 为弧集的有向图G = (V, A) 上定义如下的权函数:6 J  m- g8 ]2 T( |( \( o1 P2 p4 T& Y

    ) {  M2 r+ f# B& l(i) L : A → R 为孤上的权函数,弧 (i, j)∈ A 对应的权 L(i, j) 记为 ,称为孤 (i, j) 的容量下界(lower bound);
    ( c2 z! ^0 f8 f: @- J0 E
    * Z( k  T. V+ z0 L- ?(ii)U : A → R 为弧上的权函数,弧(i, j)∈ A对应的权U(i, j) 记为 ,称为孤 (i, j) 的容量上界或容量(capacity);
    $ s; N4 }1 @3 b8 U3 a
    0 A, `7 u) B, x(iii) D :V → R 为顶点上的权函数,节点i ∈V 对应的权 D(i) 记为  ,称为顶 点i 的供需量(supply/demand);/ q0 |5 R/ n7 |  l# h2 i
    ; ^$ n0 ]  Z  J) x$ F: P4 z
    此时所构成的网络称为流网络,可以记为 N = (V, A, L,U,D) 。 由于我们只讨论V, A 为有限集合的情况,所以对于弧上的权函数 L,U 和顶点上的 权函数 D ,可以直接用所有孤上对应的权和顶点上的权组成的有限维向量表示,因此 L,U, D 有时直接称为权向量,或简称权。由于给定有向图G = (V, A) 后,我们总是可 以在它的弧集合和顶点集合上定义各种权函数,所以流网络一般也直接简称为网络。& M/ p2 G; K' }4 `1 U

    ( Z# J+ h4 a3 ]) m4 C- i. T+ H在流网络中,弧(i, j) 的容量下界  和容量上界表示的物理意义分别是:通过该 弧发送某种“物质”时,必须发送的最小数量为 ,而发送的最大数量为 。顶点i ∈V 对应的供需量则表示该顶点从网络外部获得的“物质”数量( > 0时),或从该顶 点发送到网络外部的“物质”数量(< 0 时)。下面我们给出严格定义。
    . P- e) s) k; v$ W: {# h3 L# n3 X( y* G6 M; k$ l
    可行流(feasible flow)
    5 i3 }' Y9 X9 R& Z# ~" G4 d4 w) N' E+ x) }7 w% ]( |: R
    6 h* J1 e7 \; E; n

      _- h6 ^6 U3 k. v- w  _1 U
    # n$ w8 x9 Y' N7 c: N可见,当 di > 0时,表示有di 个单位的流量从网络外部流入该顶点,因此顶点i 称 为供应点(supply node)或源(source),有时也形象地称为起始点或发点等;当di < 0 时,表示有|di | 个单位的流量从该顶点流失到网络外部(或说被该顶点吸收),因此顶 点i 称为需求点(demand node)或汇(sink),有时也形象地称为终止点或收点等;当 di = 0时,顶点i 称为转运点(transshipment node)或平衡点、中间点等。此外,根据 (1)可知,对于可行网络,必有
    2 ^' `" K( S2 ?7 G; P6 d6 }8 H% N5 }  U
    6 B8 Y* a- {: k) L5 t+ a. q
    - }+ l% p  _- e& ?
    也就是说,所有节点上的供需量之和为 0 是网络中存在可行流的必要条件  F- S& D% P4 u% N. K
    * _. Q7 F4 [7 e- c& h: g# F

    7 W: C  D. }' Z6 R" g2 [$ Y
    . P) w3 W1 C- u/ G- s
    ; Y- @# T) U2 k" A6 v4 W1.2 最大流问题
    3 z& j3 x/ \% Q# E, L考虑如下流网络 N = (V, A,U,D):节点 s 为网络中唯一的源点,t 为唯一的汇点, 而其它节点为转运点。如果网络中存在可行流 f ,此时称流 f 的流量(或流值,flow value)为 (根据(3),它自然也等于 −  ),通常记为v 或v( f ) ,即" r# q3 W3 }  {4 Q, ^

    5 w2 q" Y) X" Z  r. n- f6 l8 f6 v" m6 m7 D
    对这种单源单汇的网络,如果我们并不给定  和  (即流量不给定),则网络一 般记为 N = (s,t,V, A,U) 。最大流问题( maximum flow problem )就是在 N = (s,t,V, A,U) 中找到流值最大的可行流(即最大流)。我们将会看到,最大流问题 的许多算法也可以用来求解流量给定的网络中的可行流。也就是说,当我们解决了最大 流问题以后,对于在流量给定的网络中寻找可行流的问题,通常也就可以解决了。0 _) {, w. J0 `5 B, A& E# I3 U' f

    $ p' N3 g8 r  r用线性规划描述最大流问题& i* [$ g& g$ n# `  t
    因此,用线性规划的方法,最大流问题可以形式地描述如下:# r9 B% Z; m7 ~: l* f
    % b, L: C8 K: o  w
    : ]  E/ P; b0 l% `8 n
    + N+ c: y4 w5 ~, P) |5 r& J- l, N
    定义】 如果一个矩阵 A 的任何子方阵的行列式的值都等于0,1或 −1,则称 A 是 全幺模的(totally unimodular TU,又译为全单位模的),或称 A 是全幺模矩阵。
    1 R) E7 v. w$ J7 m% \4 x9 ^3 V' c# b4 Y$ u: g: h8 C9 M
    整流定理
    % Y, j; ^( N' i【定理 7】(整流定理) 最大流问题所对应的约束矩阵是全幺模矩阵。若所有弧容量 均为正整数,则问题的最优解为整数解。 最大流问题是一个特殊的线性规划问题。我们将会看到利用图的特点,解决这个问 题的方法较之线性规划的一般方法要方便、直观得多。9 S( E3 w( L! y" L2 ?; w& U& o  ^
    - ~/ t5 m5 i1 W
    1.3 单源和单汇运输网络
    1 E: k, E/ k" h% l, p多源多汇网络 转化成单源单汇网络
    8 f& d2 E1 Z8 s) J# Z实际问题往往是多源多汇网络,为了计算的规格化,可将多源多汇网络G 化成单 源单汇网络G' 。设 X 是G 的源,Y 是G 的汇,具体转化方法如下:
    ( C" Q* Q2 M, ]% @+ s0 V
    + P4 ^5 b* O! y) F6 l7 x(i)在原图G 中增加两个新的顶点 x 和 y ,令为新图G' 中之单源和单汇,则G 中 所有顶点V 成为G' 之中间顶点集。# y8 ^' {1 t1 \% n5 A. g

    # h( W5 i. p5 Z8 n2 T5 E! ?# {(ii)用一条容量为∞的弧把 x 连接到 X 中的每个顶点。
    ' p' O# v% v4 h4 |
    ' ~: ?8 t, o9 t" E4 }(iii)用一条容量为∞的弧把Y 中的每个顶点连接到 y 。 G 和G' 中的流以一个简单的方式相互对应。若 f 是G 中的流,则由
    * m0 K1 ~+ _: S% s5 P5 S- ~; j5 J/ b

    6 T& p! s5 M! b. e/ |1 T  p; L9 l9 y2 F: m% l5 j
    2 最大流和最小割关系割的容量
    ' r  l# `$ D  [6 f9 l, W" y8 d! X6 ?# g' x) r7 N

    8 {/ D4 D" A7 P6 A5 ?; t( h# N& t
    则在这条可增广轨上每条前向弧的流都可以增加一个量δ ,而相应的后向弧的流可减 少δ ,这样就可使得网络的流量获得增加,同时可以使每条弧的流量不超过它的容量, 而且保持为正,也不影响其它弧的流量。总之,网络中 f 可增广轨的存在是有意义的, 因为这意味着 f 不是最大流。
    ; M+ d6 }+ G+ a0 h7 a5 z
    # ~* ?4 X5 Z  i6 ^- k3 最大流的一种算法—标号法: Q" w; H% K- t
    标号法是由 Ford 和 Fulkerson 在 1957 年提出的。用标号法寻求网络中最大流的基 本思想是寻找可增广轨,使网络的流量得到增加,直到最大为止。即首先给出一个初始 流,这样的流是存在的,例如零流。如果存在关于它的可增广轨,那么调整该轨上每条 弧上的流量,就可以得到新的流。对于新的流,如果仍存在可增广轨,则用同样的方法 使流的值增大,继续这个过程,直到网络中不存在关于新得到流的可增广轨为止,则该 流就是所求的最大流。
    4 {) _) t$ i; r; I1 \# N, L" i! H3 L: p$ u/ l
    这种方法分为以下两个过程:3 @, w3 ?. i' T, d& P& I( P  B

    6 Z- v& ]' F- R2 r4 KA.标号过程:通过标号过程寻找一条可增广轨。
    ( G$ B) W0 ?; P& @+ c* \' Q+ F! D! Y9 \  P3 ?# y# Z3 Q
    B.增流过程:沿着可增广轨增加网络的流量。" R& U+ g5 ?- I

    6 u+ T' y' d' c0 d9 K! n& V这两个过程的步骤分述如下。
    ( `- V$ m* {  r! Q% k3 \! z" c6 h6 ~' P$ C: w2 W
    (A)标号过程:" B0 W$ a/ p' J  h  R
    - C, x6 l2 J* P  K* o4 J) ?
    7 Q" h6 {# }' b
    7 A- d8 X* A1 h
    (B)增流过程' _( M) S3 z9 B* Z
    0 ^5 g  x1 i% \4 q4 p5 ]' S
    网络最大流 x 的求解步骤
    , E# h8 k# D7 F- a1 I: z7 h求网络 N = (s,t,V, A,U) 中的最大流 x 的算法的程序设计具体步骤如下:
    ! ^. r, q+ {" [# u
    , g% c& c+ d% H对每个节点 j ,其标号包括两部分信息 (pred( j),maxf(j))
    ' m; v' A& Y  [1 a5 ^9 U4 `; ~
    + \3 |/ M3 G8 ]) Y+ k8 H该节点在可能的增广路中的前一个节点 pred( j) ,以及沿该可能的增广路到该节点为止 可以增广的最大流量 maxf( j)。9 j, D6 j% d- m; T: J* f3 D
    # o# V4 e5 d0 |. M' S7 {
    8 c" C% X6 f4 C

    ) J& Z8 a+ b! ^2 S/ C+ X

    并将 j 加入 LIST 中。

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

    : {; @* o7 i5 }6 f2 V; z

    ( P. Z6 B+ S& n: q
    1 }' j/ q5 A' U" V' R8 U( s, e3 r解 编写程序如下:
    5 [! ^5 K4 h. `# D
    ( Y% `3 R! Z/ X: V# yclc,clear' K4 ]7 W# J" j
    u(1,2)=1;u(1,3)=1;u(1,4)=2;u(2,3)=1;u(2,5)=2;
    & b6 q# C  \& m0 Ou(3,5)=1;u(4,3)=3;u(4,5)=3;/ T$ y  x* c1 T- k! S
    f(1,2)=1;f(1,3)=0;f(1,4)=1;f(2,3)=0;f(2,5)=1;
    ; `, n  d" w  I* a1 K5 Lf(3,5)=1;f(4,3)=1;f(4,5)=0;2 `3 }# A5 f  D; E
    n=length(u);list=[];maxf(n)=1;. J  |1 [# P" N( W
    while maxf(n)>0
    6 G, j( B0 `( M" d. C6 T6 ~maxf=zeros(1,n);pred=zeros(1,n);8 ~. {7 Z% W7 U5 t* z0 H
    list=1;record=list;maxf(1)=inf;
      ^" q+ }( m. S# B( X# x  l& s % list是未检查邻接点的标号点,record是已标号点
    ' d. p' P# J. |/ s% N, X, Pwhile (~isempty(list))&(maxf(n)==0)
    5 Z. e8 ^& l2 O    flag=list(1);list(1)=[];
    : t8 X7 |: P% z# o& ^: V' B    label1= find(u(flag,-f(flag,);7 M$ O9 |6 w" D
        label1=setdiff(label1,record);  v( V1 X+ j9 }, Y* ]
        list=union(list,label1);
    - a" p; a2 l/ l* s6 m3 O. z    pred(label1)=flag;. U$ k6 n6 {. Q5 c5 j
        maxf(label1)=min(maxf(flag),u(flag,label1)...* Q2 ]( H* b+ I# W
        -f(flag,label1));
    7 Q  Q9 `* o4 E& u( Y    record=union(record,label1);0 p4 \: y& |( V1 A4 I) r5 Z4 }5 Y4 V
        label2=find(f(:,flag));+ M/ M! R4 a- [- q9 A) M
        label2=label2';
    ( X! {6 U7 M& A( x+ B4 \) h4 }    label2=setdiff(label2,record);
    ( I0 u% Q# m3 \. i    list=union(list,label2);! H' l+ j% }: [2 @
        pred(label2)=-flag;
    $ b( B- I6 R7 n' O    maxf(label2)=min(maxf(flag),f(label2,flag));
    0 E( g, h0 U5 c3 P7 e    record=union(record,label2);4 c9 h- L- r+ I+ ]" B& [5 h4 p' a. c
    end
    " Z2 p. ]2 C5 c, j9 m+ m     if maxf(n)>0
    + U9 b( |5 Y: A" Z; u0 u        v2=n; v1=pred(v2);3 h( i6 J3 h8 _* Q5 n6 s
            while v2~=1
    1 C* K3 X3 |; U            if v1>0
    9 P0 w; l9 u1 w6 U$ n3 ?* G                f(v1,v2)=f(v1,v2)+maxf(n);1 S+ G8 ~5 T( [
                else+ c: Z3 X; h( e  Y, n& |. b; @2 U
                    v1=abs(v1);
    0 |0 q/ z( \' E2 [& _/ l' v$ K1 {                f(v2,v1)=f(v2,v1)-maxf(n);
    8 c) y  r1 O! D" {9 t1 B            end% {1 J: |% l# M) T$ u
                v2=v1; v1=pred(v2);
    5 J! H! T9 R" {' L7 s' g) x        end
    3 M0 C( D# n- v7 Z' W    end( ?. j0 S# O* J# x& [+ W
    end
    4 l; R4 e" ]6 I5 F& |f " s  a* U) U( z9 h% H
    例18 现需要将城市 s 的石油通过管道运送到城市t ,中间有4个中转站  v1 ,v2 ,v3 和  v4 ,城市与中转站的连接以及管道的容量如图7所示,求从城市 s 到城市t 的最大流。
    0 z. u, g: y! ?+ a$ ~! b
    8 V# C6 m" k2 C. J/ A. e6 E8 X9 I
    8 c' F: a0 S: j$ F2 F5 t. x8 L

    5 n! y+ `" i8 o1 V5 n2 T解 使用最大流的数学规划表达式,编写LINGO程序如下:; X, r) l0 u7 q3 T+ y& a6 G7 G8 M" d

    7 j8 ?) e# f( M9 X: L& cmodel:
    ; A& a% k( m3 W1 ?sets:7 B. S) j* n. C2 |" H# U- l) C" ~
    nodes/s,1,2,3,4,t/;
    * a, n7 N. Z& V2 r! v0 darcs(nodes,nodes)/s 1,s 3,1 2,1 3,2 3,2 t,3 4,4 2,4 t/:c,f;
    , o& H' ^: w, P6 ^" i0 kendsets
    8 G. e5 _2 z& E6 Y1 S! f; ddata:( |% r$ C' L/ Z5 u2 [
    c=8 7 9 5 2 5 9 6 10;
    ' `) [' R- i, h( L& P* genddata- Q. C7 g: m9 D  V3 F: c
    n=@size(nodes); !顶点的个数;1 F- m  C  ]& {* \$ b! J
    max=flow;
    9 M( i& X; J1 \2 i" j7 L@for(nodes(i)|i #ne#1 #and# i #ne# n:
    ( Q" h" v; _* v$ D& P    @sum(arcs(i,j):f(i,j))=@sum(arcs(j,i):f(j,i). ~4 _% p! G2 g+ m5 @
    @sum(arcs(i,j)|i #eq# 1:f(i,j))=flow;- u; S# g9 Q" h: s6 a
    @sum(arcs(i,j)|j #eq# n:f(i,j))=flow;
    " C+ ^$ H0 ]. R1 M! F8 G  t! x@for(arcsbnd(0,f,c));
    5 p8 B3 \/ M, Z$ e1 T% Eend
      g& `) }3 [1 |; ~6 X# [
    . r! F" n" \* ]5 O1 j在上面的程序中,采用了稀疏集的编写方法。下面介绍的程序编写方法是利用赋权邻 接矩阵,这样可以不使用稀疏集的编写方法,更便于推广到复杂网络。9 G6 }6 [1 u) }/ v; _/ L( F

    6 Y. p0 _7 p( P/ {model:
    3 l- h! U8 `9 i8 v* msets:5 O. B, `$ P) X; u5 o
    nodes/s,1,2,3,4,t/;: `; ?" L5 f2 i7 F
    arcs(nodes,nodes):c,f;8 e' ]$ ~" F# k9 M
    endsets% `! t* N0 o% C" v  l+ G
    data:
    9 }1 }( ^" `' n# X6 E* q9 tc=0;: @% p/ F% n) c- Q! x
    @text('fdata.txt')=f;
    - y$ T/ g1 f2 ]- H5 genddata
    + R5 G: }1 u7 w4 f/ n; Zcalc:
    9 V% Z" ~! n- z# ^2 B, oc(1,2)=8;c(1,4)=7;
    ) ~, V; ^% d+ I( h/ Mc(2,3)=9;c(2,4)=5;; k) W4 q0 r. b- x+ w# C+ o6 i5 P
    c(3,4)=2;c(3,6)=5;
    " W) w; r' I8 p: O  {7 `c(4,5)=9;c(5,3)=6;c(5,6)=10;) o- r4 J+ S6 [
    endcalc6 {7 _9 L) P2 z) L  k
    n=@size(nodes); !顶点的个数;
    ) D. k; n9 t4 T6 C- wmax=flow;
    1 b8 k% l( H' n  X4 X7 |@for(nodes(i)|i #ne#1 #and# i #ne# n:% h6 N. U& ]3 W- \& y
        @sum(nodes(j):f(i,j))=@sum(nodes(j):f(j,i)));& T1 v$ L4 n5 e5 B* O
    @sum(nodes(i):f(1,i))=flow;% E) ?) q7 M) t" _
    @sum(nodes(i):f(i,n))=flow;" Z4 a, R- @5 F; c! W5 h
    @for(arcsbnd(0,f,c));4 Z0 Q. u1 o) K! J
    end& l4 Z- r' H$ f0 r$ l3 S( O2 v

    : _; N/ l. |3 j) ]* n6 C' G————————————————
    # z1 e0 r+ J' n版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    1 t  ~/ w$ l1 V" [  ]1 W原文链接:https://blog.csdn.net/qq_29831163/article/details/89786313
    + r( b  j  H- e: b2 ^7 e
    * K& O+ M# k/ d5 w) x& _7 r* c7 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, 2025-8-19 21:50 , Processed in 0.318099 second(s), 51 queries .

    回顶部