QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1976|回复: 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 最大流问题的数学描述
    ! E( v! ?9 i" _! X- f6 t1.1 网络中的流 定义
    7 U0 B6 r' U1 U4 g- v% ^" H在以V 为节点集, A 为弧集的有向图G = (V, A) 上定义如下的权函数:
    + [$ L9 N( N% L4 ^) K
    + V$ c9 U( [" x1 a0 }% T0 F(i) L : A → R 为孤上的权函数,弧 (i, j)∈ A 对应的权 L(i, j) 记为 ,称为孤 (i, j) 的容量下界(lower bound);/ [4 }8 O8 \* ~& u2 I" ^

    : B2 ?- A0 l0 v+ v(ii)U : A → R 为弧上的权函数,弧(i, j)∈ A对应的权U(i, j) 记为 ,称为孤 (i, j) 的容量上界或容量(capacity);, `# e! f( b! ^" m" h# v5 r6 B, o
    # B* ^) ^. D; Z+ `
    (iii) D :V → R 为顶点上的权函数,节点i ∈V 对应的权 D(i) 记为  ,称为顶 点i 的供需量(supply/demand);) R8 Q( g4 s; K+ b. M7 x

    2 F6 `, f8 e% n3 B" Q) F# `4 d此时所构成的网络称为流网络,可以记为 N = (V, A, L,U,D) 。 由于我们只讨论V, A 为有限集合的情况,所以对于弧上的权函数 L,U 和顶点上的 权函数 D ,可以直接用所有孤上对应的权和顶点上的权组成的有限维向量表示,因此 L,U, D 有时直接称为权向量,或简称权。由于给定有向图G = (V, A) 后,我们总是可 以在它的弧集合和顶点集合上定义各种权函数,所以流网络一般也直接简称为网络。/ m% X4 |% t3 V* a% L1 a! o0 J

    9 h' |- ^. k7 E) t: _在流网络中,弧(i, j) 的容量下界  和容量上界表示的物理意义分别是:通过该 弧发送某种“物质”时,必须发送的最小数量为 ,而发送的最大数量为 。顶点i ∈V 对应的供需量则表示该顶点从网络外部获得的“物质”数量( > 0时),或从该顶 点发送到网络外部的“物质”数量(< 0 时)。下面我们给出严格定义。! J* d+ |7 U* z$ n: [5 [

    # _) @) D. _+ z2 T+ ^: H可行流(feasible flow)
    - D, [. X) S' N4 \- x
    . X% e/ N& v" f3 l/ X; l2 d/ B& q( [0 b

    " l) M1 i' V- G. O) V/ J8 s9 v) Q- O, O+ ?
    可见,当 di > 0时,表示有di 个单位的流量从网络外部流入该顶点,因此顶点i 称 为供应点(supply node)或源(source),有时也形象地称为起始点或发点等;当di < 0 时,表示有|di | 个单位的流量从该顶点流失到网络外部(或说被该顶点吸收),因此顶 点i 称为需求点(demand node)或汇(sink),有时也形象地称为终止点或收点等;当 di = 0时,顶点i 称为转运点(transshipment node)或平衡点、中间点等。此外,根据 (1)可知,对于可行网络,必有; ~8 k* |; M1 f

    . @+ z; H% W2 p" x1 u9 k. E! l+ u
    3 v/ C+ K/ q* A
    * X5 }* o+ R/ V3 u3 u也就是说,所有节点上的供需量之和为 0 是网络中存在可行流的必要条件
    ; D2 p" D5 |3 \- `1 {0 M5 @8 h0 r+ P
    4 b3 m1 u- S- S: B
    $ J( l8 C, Y; b8 Q- Z# r
    ; r) ?! S& H1 F: ?: K# `
    1.2 最大流问题
    & n: t2 z7 g# F" t& G: V考虑如下流网络 N = (V, A,U,D):节点 s 为网络中唯一的源点,t 为唯一的汇点, 而其它节点为转运点。如果网络中存在可行流 f ,此时称流 f 的流量(或流值,flow value)为 (根据(3),它自然也等于 −  ),通常记为v 或v( f ) ,即
    + z' f  F; T; Y9 v- s
    8 s# L: G: N' |& q( ~  ~5 U; @. I. u# `0 m6 h: Q( y( j( }
    对这种单源单汇的网络,如果我们并不给定  和  (即流量不给定),则网络一 般记为 N = (s,t,V, A,U) 。最大流问题( maximum flow problem )就是在 N = (s,t,V, A,U) 中找到流值最大的可行流(即最大流)。我们将会看到,最大流问题 的许多算法也可以用来求解流量给定的网络中的可行流。也就是说,当我们解决了最大 流问题以后,对于在流量给定的网络中寻找可行流的问题,通常也就可以解决了。1 X/ j8 n6 w: Y+ V' C7 W: Z

    5 o/ r  N* f6 `) K3 P7 V3 s+ ]用线性规划描述最大流问题8 @+ n/ e# V/ c0 d" n$ H
    因此,用线性规划的方法,最大流问题可以形式地描述如下:4 c4 }9 K' a! j  F: c2 N' P

    + q$ j! u% L7 J( b$ g; D! c1 `4 r9 z2 a: H
    , u- K6 Y; Y" X
    定义】 如果一个矩阵 A 的任何子方阵的行列式的值都等于0,1或 −1,则称 A 是 全幺模的(totally unimodular TU,又译为全单位模的),或称 A 是全幺模矩阵。: A) t5 I- w: q. m; I

    # g' [6 D: U  J+ k4 h- X1 }4 O整流定理* @5 m& Q. L: k/ X! o+ i
    【定理 7】(整流定理) 最大流问题所对应的约束矩阵是全幺模矩阵。若所有弧容量 均为正整数,则问题的最优解为整数解。 最大流问题是一个特殊的线性规划问题。我们将会看到利用图的特点,解决这个问 题的方法较之线性规划的一般方法要方便、直观得多。
    , ]6 E9 c- v4 T+ ?
    + `0 j0 b. i1 h. W- I3 _1.3 单源和单汇运输网络
    $ A* o+ R8 {2 U( m1 x: ?- _6 p多源多汇网络 转化成单源单汇网络( A/ ^* Q* d* t) U( }6 Z
    实际问题往往是多源多汇网络,为了计算的规格化,可将多源多汇网络G 化成单 源单汇网络G' 。设 X 是G 的源,Y 是G 的汇,具体转化方法如下:5 t5 E& \/ A& `; N8 v4 \
    . \- o! g+ c8 S+ U6 ]  y1 ]
    (i)在原图G 中增加两个新的顶点 x 和 y ,令为新图G' 中之单源和单汇,则G 中 所有顶点V 成为G' 之中间顶点集。: H# g7 g' Y  y9 U. Z( V
    & y1 C" `% X0 t! l8 k8 `1 q
    (ii)用一条容量为∞的弧把 x 连接到 X 中的每个顶点。/ Q* B, R% O! ~
    # S, u0 C& F$ l: ]& U0 G0 T
    (iii)用一条容量为∞的弧把Y 中的每个顶点连接到 y 。 G 和G' 中的流以一个简单的方式相互对应。若 f 是G 中的流,则由  E  n. S# w- ]$ C# c/ j- M

    - C- w' A2 z) V5 Z* }  ^  J+ d7 d2 a" U# m
    4 D  y" @; X- i
    2 最大流和最小割关系割的容量. G) a% a, O2 @, K

    , O! \+ s& v6 f2 c% d0 W( z/ {* E9 M2 }3 c+ T

    4 O4 \+ ?; M* D! }" x# E/ m则在这条可增广轨上每条前向弧的流都可以增加一个量δ ,而相应的后向弧的流可减 少δ ,这样就可使得网络的流量获得增加,同时可以使每条弧的流量不超过它的容量, 而且保持为正,也不影响其它弧的流量。总之,网络中 f 可增广轨的存在是有意义的, 因为这意味着 f 不是最大流。
      |5 r( i) u& b( r4 ~. K0 E/ N! \/ b6 J/ q" [
    3 最大流的一种算法—标号法
    + X3 O& m  h9 q/ o3 B标号法是由 Ford 和 Fulkerson 在 1957 年提出的。用标号法寻求网络中最大流的基 本思想是寻找可增广轨,使网络的流量得到增加,直到最大为止。即首先给出一个初始 流,这样的流是存在的,例如零流。如果存在关于它的可增广轨,那么调整该轨上每条 弧上的流量,就可以得到新的流。对于新的流,如果仍存在可增广轨,则用同样的方法 使流的值增大,继续这个过程,直到网络中不存在关于新得到流的可增广轨为止,则该 流就是所求的最大流。
    2 e0 p* D5 N5 ~
    1 n8 }) M- _  A) i9 g$ k这种方法分为以下两个过程:
    ; A9 N' C9 L( o$ X  O  b- k# o3 g+ A$ n
    A.标号过程:通过标号过程寻找一条可增广轨。# }6 E( c! O% s

      Z* [' {# e! L) a0 CB.增流过程:沿着可增广轨增加网络的流量。' R5 P: g" O. F
    1 u) Z9 n" }/ h9 d
    这两个过程的步骤分述如下。
    " E! ?9 T! z  [6 H7 |6 a' D/ O6 O
    (A)标号过程:, Y) I& s+ M5 M9 [6 Q0 _: G$ s
    . s. V. o6 ~8 h& k) O
    ( {; r4 u# W* [, A  N% ^2 _
    : y4 z7 h1 w; L# ~7 S3 f( z  p
    (B)增流过程
    ) ~0 j+ N( A! P; |
    4 E$ u! E% ^# t' ]# _) b4 @" J网络最大流 x 的求解步骤  m' s! U& O6 U$ u, G
    求网络 N = (s,t,V, A,U) 中的最大流 x 的算法的程序设计具体步骤如下:
    5 Z. y0 @. ?% O; h; I* \# i. v/ I8 ~( p* b: a
    对每个节点 j ,其标号包括两部分信息 (pred( j),maxf(j))
    + {5 Y; L+ V; ~- I: }4 [; T/ t+ b. c6 O2 n- E' @
    该节点在可能的增广路中的前一个节点 pred( j) ,以及沿该可能的增广路到该节点为止 可以增广的最大流量 maxf( j)。
    2 ?5 J+ f* n7 `+ t) U& I1 o1 [2 I

    7 v, P8 I/ J& m6 V  B
    5 [! x) U4 h* K/ y2 Y, C

    并将 j 加入 LIST 中。

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


    5 X0 @( M) H) s7 H# _
    ) x- t; I5 n0 Q+ Y/ ~% q8 J; @% I" F2 w. h# d
    解 编写程序如下:1 x$ o" C/ V# U0 j8 f8 T0 B$ y2 M

    + d. t( m1 d+ Z* z  I8 m% Cclc,clear
    ! T# W0 l" o  @- F" W" k; i) Y3 v$ tu(1,2)=1;u(1,3)=1;u(1,4)=2;u(2,3)=1;u(2,5)=2;& f- m8 G* S4 S6 C3 s
    u(3,5)=1;u(4,3)=3;u(4,5)=3;; a8 |7 r# W! ~0 `
    f(1,2)=1;f(1,3)=0;f(1,4)=1;f(2,3)=0;f(2,5)=1;
    - @  R# ~' c" Jf(3,5)=1;f(4,3)=1;f(4,5)=0;
    ( ]3 n! R( E  B( I& nn=length(u);list=[];maxf(n)=1;9 F& k4 d% j' T: e( t8 u; V) Z* R  j- Y
    while maxf(n)>0
    ( d: p- u, \: _, w- T4 w4 q7 bmaxf=zeros(1,n);pred=zeros(1,n);
    " E, g* h& X1 s- \2 p( Llist=1;record=list;maxf(1)=inf;
      J: }! H9 K; y0 x, ^5 O % list是未检查邻接点的标号点,record是已标号点" \( }5 i  d1 n% z
    while (~isempty(list))&(maxf(n)==0)! ~6 ], f- A4 T: x6 d
        flag=list(1);list(1)=[];/ X1 {$ t" s9 J6 {  v0 N
        label1= find(u(flag,-f(flag,);% ~3 ]: w  x) O; K6 [% J# J' e! C, Y* P
        label1=setdiff(label1,record);
    7 Z/ e9 u0 V! P2 X. `& ]    list=union(list,label1);
    ; t" o/ o0 i9 P) W8 f* w! w    pred(label1)=flag;
    * X9 B& s" d7 L6 W8 O3 o    maxf(label1)=min(maxf(flag),u(flag,label1)...) K" _$ o+ K6 j
        -f(flag,label1));
    5 P8 D+ @2 ~+ p& n    record=union(record,label1);
    . y4 U. t$ k" b    label2=find(f(:,flag));
    ) Y1 E; {. n* B    label2=label2';0 L5 z) P# @$ Q0 }  |( f
        label2=setdiff(label2,record);9 W. x/ q4 k: {) n' v& w1 A4 z
        list=union(list,label2);
    8 R8 ?9 @: C5 x. M    pred(label2)=-flag;
    , y8 Y$ e. R. H9 a    maxf(label2)=min(maxf(flag),f(label2,flag));
    1 G) o% I+ Q3 N9 p! w, x- p' W! \    record=union(record,label2);  o. _8 A% H4 O
    end1 h: A7 Y( r4 i' A8 Z& h) ^
         if maxf(n)>0" \+ r' N/ y$ v7 X  N4 C
            v2=n; v1=pred(v2);5 {8 b  F0 J# U# q5 Z) H7 D
            while v2~=1" ^7 |2 v) D- @; [" y9 x
                if v1>0! a% _: C! Z+ h0 d% j3 S/ f0 {
                    f(v1,v2)=f(v1,v2)+maxf(n);
    + _' M# N7 I5 r! J/ h            else
    + K0 w+ L; O6 \( u2 ]7 p                v1=abs(v1);5 V- `+ q& n( g* _1 e
                    f(v2,v1)=f(v2,v1)-maxf(n);
    9 w3 F# C) ~. k0 {# ^& f' I            end$ ~' `) d- v5 ~* c2 g* B7 |+ C, I
                v2=v1; v1=pred(v2);" r7 P! }' \: y, y: o" `1 Z% a
            end
    ) d, I9 h7 u, ]0 u& \    end: G7 e! W; t4 P
    end
      E$ t6 i. c$ a" i* [/ n$ n. qf # j8 u' K! u3 C7 t. ?6 u8 Y
    例18 现需要将城市 s 的石油通过管道运送到城市t ,中间有4个中转站  v1 ,v2 ,v3 和  v4 ,城市与中转站的连接以及管道的容量如图7所示,求从城市 s 到城市t 的最大流。
    4 P: Y6 \: @; v) c9 c9 h/ C
    & H" I. p& t& E
    1 u! S. Z) h+ G% ?8 T4 q2 i+ d( O4 Z+ \* V: M

    . O/ m) L- i, t# M解 使用最大流的数学规划表达式,编写LINGO程序如下:
    7 N0 g/ f7 q' U9 S# R+ [1 p2 g  P5 f. ^; T* a: s+ U7 W
    model:
    : G- Z  b* e& V4 j& w0 Nsets:( J3 R( {, B/ r" ~/ x  P
    nodes/s,1,2,3,4,t/;' ]/ L/ R, }' M
    arcs(nodes,nodes)/s 1,s 3,1 2,1 3,2 3,2 t,3 4,4 2,4 t/:c,f;: a& |8 f+ F5 a8 E7 V7 i. r: _
    endsets' P% R2 w0 ?$ s( F
    data:
    - _5 M- l% g  Z' Q; Hc=8 7 9 5 2 5 9 6 10;
    8 F" M5 X3 Y% z! H8 [8 ^: `enddata8 z$ ^# z( T6 V
    n=@size(nodes); !顶点的个数;
    6 e3 B: O5 E- t- M/ K* Omax=flow;* Y/ F+ y: I: k$ T- r" @- f( w- R
    @for(nodes(i)|i #ne#1 #and# i #ne# n:
    3 X# Y" S( O& V- c' w4 ~" I    @sum(arcs(i,j):f(i,j))=@sum(arcs(j,i):f(j,i)
    0 t2 M2 s9 u% R) G" P1 @@sum(arcs(i,j)|i #eq# 1:f(i,j))=flow;0 ^) u6 A+ B* v9 c8 n+ V. l3 Q" p* V
    @sum(arcs(i,j)|j #eq# n:f(i,j))=flow;( N) S: b# c! v- ~% S1 @
    @for(arcsbnd(0,f,c));
    $ _! y: b# c; i3 send : j$ T7 ]  Y& y1 a( D

    2 \+ q2 {& \+ v' U. _在上面的程序中,采用了稀疏集的编写方法。下面介绍的程序编写方法是利用赋权邻 接矩阵,这样可以不使用稀疏集的编写方法,更便于推广到复杂网络。& f/ h1 w% g' s' L

    + X' O3 Q" f, O! Amodel:1 z$ S$ A- j: @$ j+ K
    sets:# ~1 @) v! E) |& O5 M5 V
    nodes/s,1,2,3,4,t/;
      D6 Q$ y1 {4 k9 l3 v: f- qarcs(nodes,nodes):c,f;
    9 \5 C7 F2 q, ]/ i& _endsets  T, G% c; h8 g5 ?& K+ S
    data:
    2 K: J1 T/ |4 T# H% D/ i3 a' ?6 c) Rc=0;% H0 F; }; X) m- I; Q# g
    @text('fdata.txt')=f;1 j8 r- w" Z( e  w9 S% ?
    enddata0 d/ L% ]3 r$ h$ j( G" e
    calc:
    1 D. _% g# O1 h) uc(1,2)=8;c(1,4)=7;
    8 r) u: ^; c" H7 c5 w' P9 [  Uc(2,3)=9;c(2,4)=5;( D, |' a" W* p% |- T% V6 p6 X
    c(3,4)=2;c(3,6)=5;
    9 q8 w! o/ }# m' H3 ^/ ^1 Q+ Rc(4,5)=9;c(5,3)=6;c(5,6)=10;6 b, @5 P2 Q' Z) H
    endcalc5 C2 A: o! M" H3 x! U
    n=@size(nodes); !顶点的个数;1 c& ?& W6 F/ n) n7 l
    max=flow;
    / g7 _6 y4 A5 d1 R4 v@for(nodes(i)|i #ne#1 #and# i #ne# n:
    ) K1 @7 Q- a% d! g    @sum(nodes(j):f(i,j))=@sum(nodes(j):f(j,i)));) y2 [0 Y+ @# f! y
    @sum(nodes(i):f(1,i))=flow;
    ' ~0 o- }  W; S1 e" }@sum(nodes(i):f(i,n))=flow;
    5 ]* X* e& ]$ {9 o" q@for(arcsbnd(0,f,c));
    ( c5 U1 x7 T, }3 i; [end: Q0 l" L$ t, x6 y

    $ i. ]2 d/ x* l5 Q) h3 F( ?. m/ T# `6 A1 Y————————————————
    2 N& p( I5 A) e0 o. H( F版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    8 s1 G7 p  Y1 \$ D# |6 r4 M原文链接:https://blog.csdn.net/qq_29831163/article/details/897863136 T5 u3 m0 I3 ^: [

    ' c" K5 q. g3 Q, s6 H1 o6 N- j6 L5 A5 |. @2 a9 h+ F' V6 ?
    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-14 00:51 , Processed in 0.417367 second(s), 50 queries .

    回顶部