QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1679|回复: 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 最大流问题的数学描述. A' Q1 [% E# X
    1.1 网络中的流 定义
    / W( i! J4 s1 g' F在以V 为节点集, A 为弧集的有向图G = (V, A) 上定义如下的权函数:' T7 a" i4 ?3 q6 C" C  G% O

    9 M% ^' A8 U  l" E3 f(i) L : A → R 为孤上的权函数,弧 (i, j)∈ A 对应的权 L(i, j) 记为 ,称为孤 (i, j) 的容量下界(lower bound);; `0 g2 q& E) x* S

    % f8 E0 t+ n5 N1 Q(ii)U : A → R 为弧上的权函数,弧(i, j)∈ A对应的权U(i, j) 记为 ,称为孤 (i, j) 的容量上界或容量(capacity);
    1 \* I6 j! O2 E2 ?* G' |! J  R- A: f7 Q* s( {- {
    (iii) D :V → R 为顶点上的权函数,节点i ∈V 对应的权 D(i) 记为  ,称为顶 点i 的供需量(supply/demand);
    6 _8 N* B- @3 t! Y3 @  U6 g) O4 z/ Q. y/ w+ }" _
    此时所构成的网络称为流网络,可以记为 N = (V, A, L,U,D) 。 由于我们只讨论V, A 为有限集合的情况,所以对于弧上的权函数 L,U 和顶点上的 权函数 D ,可以直接用所有孤上对应的权和顶点上的权组成的有限维向量表示,因此 L,U, D 有时直接称为权向量,或简称权。由于给定有向图G = (V, A) 后,我们总是可 以在它的弧集合和顶点集合上定义各种权函数,所以流网络一般也直接简称为网络。: c+ T! t3 I( W' s& y
    - v$ Q9 x7 ], n3 {$ u/ K: {
    在流网络中,弧(i, j) 的容量下界  和容量上界表示的物理意义分别是:通过该 弧发送某种“物质”时,必须发送的最小数量为 ,而发送的最大数量为 。顶点i ∈V 对应的供需量则表示该顶点从网络外部获得的“物质”数量( > 0时),或从该顶 点发送到网络外部的“物质”数量(< 0 时)。下面我们给出严格定义。
    6 j/ `+ x! ^/ ?  S- j) r/ H5 c. j; k9 V; z# M! R; U
    可行流(feasible flow)
    0 A8 }+ S: W  T% T* L. c
    , x2 F% i* n& Z% n" w
    / P/ d% O9 Z; g# Z  s* s' S$ j9 L# v2 {( J
    0 [! `7 X0 G8 v" K
    可见,当 di > 0时,表示有di 个单位的流量从网络外部流入该顶点,因此顶点i 称 为供应点(supply node)或源(source),有时也形象地称为起始点或发点等;当di < 0 时,表示有|di | 个单位的流量从该顶点流失到网络外部(或说被该顶点吸收),因此顶 点i 称为需求点(demand node)或汇(sink),有时也形象地称为终止点或收点等;当 di = 0时,顶点i 称为转运点(transshipment node)或平衡点、中间点等。此外,根据 (1)可知,对于可行网络,必有3 x, c; x3 L" z( V; e4 V2 ^

    - N: y! b* k  q$ Q( E6 _. }
    : ]& j  T: z) d5 e, a' g. C; u) g
    也就是说,所有节点上的供需量之和为 0 是网络中存在可行流的必要条件
    / k- Q& V. o% e# ?/ i0 g# h* {
    4 n' t% G# [" p+ p
    4 m: K2 W" J( A. J7 o; A" _' d$ n: @0 G' J7 I# p1 U+ x5 Y

    $ N) x5 p6 f" m  _& L6 D# K1.2 最大流问题. U" p" {) {$ m1 q
    考虑如下流网络 N = (V, A,U,D):节点 s 为网络中唯一的源点,t 为唯一的汇点, 而其它节点为转运点。如果网络中存在可行流 f ,此时称流 f 的流量(或流值,flow value)为 (根据(3),它自然也等于 −  ),通常记为v 或v( f ) ,即, O% ?# e1 {# x2 K$ X
    ' Z# Y$ e& D- b
    2 `0 i: U% x8 d+ |
    对这种单源单汇的网络,如果我们并不给定  和  (即流量不给定),则网络一 般记为 N = (s,t,V, A,U) 。最大流问题( maximum flow problem )就是在 N = (s,t,V, A,U) 中找到流值最大的可行流(即最大流)。我们将会看到,最大流问题 的许多算法也可以用来求解流量给定的网络中的可行流。也就是说,当我们解决了最大 流问题以后,对于在流量给定的网络中寻找可行流的问题,通常也就可以解决了。# i" L9 v$ ^  d" G

    9 d4 g& F6 M$ ^! R+ J4 |* ?6 u用线性规划描述最大流问题1 z8 N3 {; h: q/ ^
    因此,用线性规划的方法,最大流问题可以形式地描述如下:- J0 a1 j% D; y9 Z& f) ]& I

    0 B/ k1 S7 R, x4 t% F) L
    ! i, v/ Q# e' r# q" ]
    + x( @# E0 ]  h. u6 i9 N" K9 C定义】 如果一个矩阵 A 的任何子方阵的行列式的值都等于0,1或 −1,则称 A 是 全幺模的(totally unimodular TU,又译为全单位模的),或称 A 是全幺模矩阵。6 a! W, \+ L+ A1 E" v

    ; e9 ^# c1 n# c: P* _1 B, [整流定理
    + _$ W8 X, U' E+ l* k! q  @8 e; B; V【定理 7】(整流定理) 最大流问题所对应的约束矩阵是全幺模矩阵。若所有弧容量 均为正整数,则问题的最优解为整数解。 最大流问题是一个特殊的线性规划问题。我们将会看到利用图的特点,解决这个问 题的方法较之线性规划的一般方法要方便、直观得多。( f" A. R* z1 g, s

    % \! S* a7 }" @+ i+ c8 |3 g1.3 单源和单汇运输网络
    . }/ t+ e& @, ?) U多源多汇网络 转化成单源单汇网络
    & m; W# {" p# I* A实际问题往往是多源多汇网络,为了计算的规格化,可将多源多汇网络G 化成单 源单汇网络G' 。设 X 是G 的源,Y 是G 的汇,具体转化方法如下:
      @' D5 M, E/ c( f# {& t
    ' B3 a, G4 |4 G% b(i)在原图G 中增加两个新的顶点 x 和 y ,令为新图G' 中之单源和单汇,则G 中 所有顶点V 成为G' 之中间顶点集。
    % u' q6 s7 Y  Y$ [8 f
    4 {+ a+ X; u5 J) m  J3 f(ii)用一条容量为∞的弧把 x 连接到 X 中的每个顶点。
    # N& b2 O% d! o5 A; Y) M! @! ~/ A1 i" N
    (iii)用一条容量为∞的弧把Y 中的每个顶点连接到 y 。 G 和G' 中的流以一个简单的方式相互对应。若 f 是G 中的流,则由6 d" b( k& [2 S5 V9 X  t& V
    1 w% T3 @1 j: G4 c* g  n+ Q

    & y5 }( m+ K( i/ `' q& L9 V4 [5 ?3 v' B$ F. J
    2 最大流和最小割关系割的容量
    % k2 p4 A1 h3 M4 b7 C" C2 K6 q
    7 O' X. w9 r3 u  y9 T; G" o9 n( N4 o' ^
    : v2 j6 h4 n5 y# f
    则在这条可增广轨上每条前向弧的流都可以增加一个量δ ,而相应的后向弧的流可减 少δ ,这样就可使得网络的流量获得增加,同时可以使每条弧的流量不超过它的容量, 而且保持为正,也不影响其它弧的流量。总之,网络中 f 可增广轨的存在是有意义的, 因为这意味着 f 不是最大流。
      Q' A4 l4 f5 ^
    * v7 N( _6 Z7 @; t# U3 最大流的一种算法—标号法
    6 z9 H9 m/ s; `' k7 ], Z标号法是由 Ford 和 Fulkerson 在 1957 年提出的。用标号法寻求网络中最大流的基 本思想是寻找可增广轨,使网络的流量得到增加,直到最大为止。即首先给出一个初始 流,这样的流是存在的,例如零流。如果存在关于它的可增广轨,那么调整该轨上每条 弧上的流量,就可以得到新的流。对于新的流,如果仍存在可增广轨,则用同样的方法 使流的值增大,继续这个过程,直到网络中不存在关于新得到流的可增广轨为止,则该 流就是所求的最大流。
    : ]$ C/ K2 p8 q% a# b2 K/ A+ W8 E( g
    这种方法分为以下两个过程:
    % ^; f3 i+ J, [5 z7 T& J8 W" k! J& f2 B
    A.标号过程:通过标号过程寻找一条可增广轨。/ F& @' X+ A/ |2 ^' Q6 K+ G$ W
    / {* e* S* b1 {; }
    B.增流过程:沿着可增广轨增加网络的流量。
    3 Y2 P; {. E/ y0 Q& I. [' I2 `" `8 h
    * c% ~) T% V' D) ~5 c  [& R这两个过程的步骤分述如下。9 Z* t- A, v) [. _1 ?& o

    1 V% I% B" D+ y' v0 b7 u6 Q3 c(A)标号过程:
    & _; L4 ?6 |0 |% r) x5 Y/ D
    $ e! g9 n4 L' \) b$ t8 {. L
    , E: q0 \- T' v0 r7 C/ {
    4 l6 \6 J" j$ o) W& g% t(B)增流过程
    - E8 |: p/ w  t, h. {/ T, r
    . g2 }. I% e# ?/ E网络最大流 x 的求解步骤
    . m& u+ _+ Y0 U8 L. c求网络 N = (s,t,V, A,U) 中的最大流 x 的算法的程序设计具体步骤如下:3 y" r& ~, |! U# u  F, ^0 M. ?$ C4 R
      Z* m" {0 h- i+ N3 W
    对每个节点 j ,其标号包括两部分信息 (pred( j),maxf(j))
    9 [% U- o. `9 S! v5 X* N7 j2 Z, u; k; r( s: c
    该节点在可能的增广路中的前一个节点 pred( j) ,以及沿该可能的增广路到该节点为止 可以增广的最大流量 maxf( j)。" I2 g! l8 W, B, j

    : H" K  `" d$ i/ _0 m+ |+ E3 R8 C! ?  C9 G6 {5 W& z- \9 d
    ' E( W1 |: m& j; q" u$ s

    并将 j 加入 LIST 中。

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


    4 z- ?- J3 w) M+ H" m- H/ W: p, P& S# w$ m3 g2 M
    ! Y+ p% T. q; d+ u7 J
    解 编写程序如下:. I% P0 V8 L# l6 w

    6 p" ^3 m" m  i7 O! C! yclc,clear/ z; B( M2 D6 S, l) q' n
    u(1,2)=1;u(1,3)=1;u(1,4)=2;u(2,3)=1;u(2,5)=2;
    3 k% _/ y0 p* K8 }0 C' g. z: T9 Ru(3,5)=1;u(4,3)=3;u(4,5)=3;
    ) U: p" J0 q: v; S1 Vf(1,2)=1;f(1,3)=0;f(1,4)=1;f(2,3)=0;f(2,5)=1;
    " w/ h" m5 j4 R3 S) G8 ^f(3,5)=1;f(4,3)=1;f(4,5)=0;7 u9 B8 X9 s. _/ q
    n=length(u);list=[];maxf(n)=1;
    : x) M. q  e* s: T" S# F$ e- [# iwhile maxf(n)>0
    ! p; L: o6 ^1 }5 m+ q1 Kmaxf=zeros(1,n);pred=zeros(1,n);
    4 u' n6 p* _* d0 ilist=1;record=list;maxf(1)=inf;
    * l, Z2 G5 F+ h % list是未检查邻接点的标号点,record是已标号点+ f7 v( J. o% {7 e5 l: _: ?
    while (~isempty(list))&(maxf(n)==0)% t, l1 E4 Y& w& f! ~9 [5 {
        flag=list(1);list(1)=[];
    ) O6 ]* R* S- \* S$ W    label1= find(u(flag,-f(flag,);
    6 Y/ A# h7 }4 X! H1 D    label1=setdiff(label1,record);
    - c4 M4 i1 d8 f# W) N% i    list=union(list,label1);
    + N  C) x8 F- Y7 w3 x5 P    pred(label1)=flag;
    ! l9 @5 T6 a5 c: F! i    maxf(label1)=min(maxf(flag),u(flag,label1)...6 z' X, Y- H$ U
        -f(flag,label1));1 e1 A3 W# Z4 I' \' B. Y1 ~
        record=union(record,label1);
    $ v/ J8 \6 [6 P. F1 x    label2=find(f(:,flag));- P  l6 h1 K- x
        label2=label2';9 ]3 c( X; Q' [+ _8 ~! [% \/ ]
        label2=setdiff(label2,record);
    ) G6 w' b- A3 \# q2 J8 _    list=union(list,label2);
    2 b9 y* v, D+ R, A  m  v* T5 \    pred(label2)=-flag;
    + a& m/ i! R. k' t. q' H  i: z    maxf(label2)=min(maxf(flag),f(label2,flag));
    6 V) u% ?5 z5 `+ m6 X    record=union(record,label2);  r9 i( h/ i( I3 E" \1 k& u5 J
    end  x9 S" @! Z5 X! M, `' d9 S
         if maxf(n)>0& i  j7 Z; D  J) W2 F
            v2=n; v1=pred(v2);9 N! g1 W4 ]6 e) G' W
            while v2~=1. h$ N7 {3 n2 [+ K# f+ }$ X
                if v1>0  L! A4 @1 D8 ?
                    f(v1,v2)=f(v1,v2)+maxf(n);2 Z# w# j" j) `3 f
                else  ]" e' s" }" P& O. @
                    v1=abs(v1);1 [2 ~; {. p- S7 \$ }" u
                    f(v2,v1)=f(v2,v1)-maxf(n);
    , N! T" H, S) s            end
      X0 l8 {* N! i9 b) h6 m% y, i& q            v2=v1; v1=pred(v2);* }) R% C3 L) f* T) |. i
            end
    / H! Q3 D- V" v/ z  |/ \! S    end' j/ E0 x7 Y- m5 y* f
    end8 U6 M! ~  H6 q) V
    f $ H8 P* U5 |' ^% R1 A
    例18 现需要将城市 s 的石油通过管道运送到城市t ,中间有4个中转站  v1 ,v2 ,v3 和  v4 ,城市与中转站的连接以及管道的容量如图7所示,求从城市 s 到城市t 的最大流。
    " G, j' `# u% |( M  C3 G0 L% h" F- {4 f; R

    ! E  P% H3 H. a# _" S5 a6 G& J. e* I' |% b
    5 r( Y! w0 G/ S- A
    解 使用最大流的数学规划表达式,编写LINGO程序如下:
    0 b+ i; J4 d0 G3 \
    $ V- x: q4 G" m! \& Wmodel:
      B6 B& ]5 U# ssets:" ^" d8 m* j, h8 P: E  S
    nodes/s,1,2,3,4,t/;* x% [* B9 ~) z% F
    arcs(nodes,nodes)/s 1,s 3,1 2,1 3,2 3,2 t,3 4,4 2,4 t/:c,f;5 w0 N9 \4 S2 I$ |1 U2 o
    endsets- X2 C8 G& A8 g5 H+ _
    data:; x: q& x4 v! {/ y
    c=8 7 9 5 2 5 9 6 10;
    : B: }/ q) [: T( C, Eenddata, o& ]: i5 W3 j5 J  o* W
    n=@size(nodes); !顶点的个数;
    & q; P' B  m( c3 A  s2 Z2 P$ c" Vmax=flow;2 q" ?: s  J8 X& N1 i- X- s- F
    @for(nodes(i)|i #ne#1 #and# i #ne# n:
    8 C7 B9 E9 x6 a# V6 ~    @sum(arcs(i,j):f(i,j))=@sum(arcs(j,i):f(j,i); e, V* @2 Q8 M
    @sum(arcs(i,j)|i #eq# 1:f(i,j))=flow;* N" k/ {& T' o. K
    @sum(arcs(i,j)|j #eq# n:f(i,j))=flow;
    ! A5 m1 q7 Z5 R8 A& c( x+ Y, E@for(arcsbnd(0,f,c));# S6 B. k' s4 {4 d
    end 7 S; i5 n2 ^9 S/ X  f+ r5 o

    6 H( t$ H+ P9 w2 I+ e在上面的程序中,采用了稀疏集的编写方法。下面介绍的程序编写方法是利用赋权邻 接矩阵,这样可以不使用稀疏集的编写方法,更便于推广到复杂网络。# N: [& E5 O1 i+ v

    , Z2 w' S0 B* D/ I/ r& b/ R! M, N  Zmodel:
    ( G5 x+ M2 n8 S1 Osets:
    & K3 X7 M  Y% lnodes/s,1,2,3,4,t/;+ a5 T7 n( E. `
    arcs(nodes,nodes):c,f;
    ; p$ S$ D( G& ~  i9 @; O# o7 dendsets
    - S; S8 }5 e. O  q% X; Z6 @) v* Odata:
    1 D% l7 y  t/ y( h: E( Z% ~c=0;
    3 t2 r  ~% F( j+ R; ]. ]7 `, A# i@text('fdata.txt')=f;
    . ?( u- j0 j' i/ Q( k* `enddata8 E% x# R- l0 M
    calc:
    ; N$ R) j) l' g9 r3 a2 fc(1,2)=8;c(1,4)=7;
    - T" x5 N) I# q1 u: z. d7 r( Dc(2,3)=9;c(2,4)=5;. m9 y3 J/ ^7 @
    c(3,4)=2;c(3,6)=5;
    & |* t) D7 j, B( @8 Y4 O* Tc(4,5)=9;c(5,3)=6;c(5,6)=10;
    $ o! m& ~7 K' n/ ]" Hendcalc- v& E+ b3 {" b4 X" @
    n=@size(nodes); !顶点的个数;
      ?! p; _* J4 t% f, ~: xmax=flow;, h* j/ |2 W7 |( ?/ e1 k
    @for(nodes(i)|i #ne#1 #and# i #ne# n:
    : R; x# t# _$ g8 X: }6 C$ r    @sum(nodes(j):f(i,j))=@sum(nodes(j):f(j,i)));& I5 D' t* `: }% s6 p8 S. ^
    @sum(nodes(i):f(1,i))=flow;4 w/ U( S- W# n3 H+ t
    @sum(nodes(i):f(i,n))=flow;
    : Q" B* e' s. C@for(arcsbnd(0,f,c));
    . B3 t7 w8 i% Zend
      D9 k% A. t6 D. g1 ?/ O" T
    - h7 T6 v( ]2 z+ V% O7 U2 _————————————————
    2 {+ H7 E" e, \  k版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    0 P2 u2 B! H; l/ Q原文链接:https://blog.csdn.net/qq_29831163/article/details/89786313: c+ K3 j/ w, e2 G

    / G8 R3 |; k8 f5 a
    3 ]$ P, y6 _# L" j% r8 w  S. E
    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-5-15 20:25 , Processed in 0.445598 second(s), 51 queries .

    回顶部