QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1947|回复: 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 最大流问题的数学描述2 F! m( J9 J; w0 L! z. }# q
    1.1 网络中的流 定义
    8 T8 z& E5 d2 A9 b& d4 ^* s" t在以V 为节点集, A 为弧集的有向图G = (V, A) 上定义如下的权函数:
    : @) I" {0 X: Y( w4 s% F/ H6 ?9 u- \1 \' L7 x4 ]& ?% }( D: i$ n  [
    (i) L : A → R 为孤上的权函数,弧 (i, j)∈ A 对应的权 L(i, j) 记为 ,称为孤 (i, j) 的容量下界(lower bound);
    . N- Z, z) \& u+ b8 G# v" D7 b; q( l% w* J2 A, a8 b; A- Z! |9 |
    (ii)U : A → R 为弧上的权函数,弧(i, j)∈ A对应的权U(i, j) 记为 ,称为孤 (i, j) 的容量上界或容量(capacity);7 C% |5 l# q8 i0 t  g, I" e) l* }

    2 p# v: {* f- X7 [(iii) D :V → R 为顶点上的权函数,节点i ∈V 对应的权 D(i) 记为  ,称为顶 点i 的供需量(supply/demand);# X9 q# [, }  D% h) ^

    5 N: T8 T, j1 X7 B1 B$ O3 ^3 _此时所构成的网络称为流网络,可以记为 N = (V, A, L,U,D) 。 由于我们只讨论V, A 为有限集合的情况,所以对于弧上的权函数 L,U 和顶点上的 权函数 D ,可以直接用所有孤上对应的权和顶点上的权组成的有限维向量表示,因此 L,U, D 有时直接称为权向量,或简称权。由于给定有向图G = (V, A) 后,我们总是可 以在它的弧集合和顶点集合上定义各种权函数,所以流网络一般也直接简称为网络。9 Q( `; a  O. c2 B: r% T; ^3 x
    + r& V$ {6 ~8 R2 m3 @
    在流网络中,弧(i, j) 的容量下界  和容量上界表示的物理意义分别是:通过该 弧发送某种“物质”时,必须发送的最小数量为 ,而发送的最大数量为 。顶点i ∈V 对应的供需量则表示该顶点从网络外部获得的“物质”数量( > 0时),或从该顶 点发送到网络外部的“物质”数量(< 0 时)。下面我们给出严格定义。
    2 l+ i$ E3 C, Y$ O3 k& X2 K$ G/ s
    可行流(feasible flow)( \( p) ]. U5 F1 B5 f3 {, ~. r
    & M+ e4 N  S/ v8 ~* U5 D5 v

    1 s$ c/ r4 r! p; F& v- h( D' y% y
    ; m: ^. c. N! s" C! l6 P
    $ X7 Y, ]( C7 {8 Q5 E+ m可见,当 di > 0时,表示有di 个单位的流量从网络外部流入该顶点,因此顶点i 称 为供应点(supply node)或源(source),有时也形象地称为起始点或发点等;当di < 0 时,表示有|di | 个单位的流量从该顶点流失到网络外部(或说被该顶点吸收),因此顶 点i 称为需求点(demand node)或汇(sink),有时也形象地称为终止点或收点等;当 di = 0时,顶点i 称为转运点(transshipment node)或平衡点、中间点等。此外,根据 (1)可知,对于可行网络,必有8 F  ~7 w/ ^0 F2 S3 Q

    % l; n  I4 `# j4 @0 J9 H( J3 c- x% t4 N

    5 }0 O. N7 x  ^  v8 i  X, T" G也就是说,所有节点上的供需量之和为 0 是网络中存在可行流的必要条件* {2 F3 c7 t- |7 g! L

    7 Z+ M% _% i( e* l( ~4 O+ q' w0 i
    9 M, r5 |- r; _' Y" e. R) W/ i

    + m- Z* J  G) `5 C1.2 最大流问题
    + M& F; C& G/ T1 w) U考虑如下流网络 N = (V, A,U,D):节点 s 为网络中唯一的源点,t 为唯一的汇点, 而其它节点为转运点。如果网络中存在可行流 f ,此时称流 f 的流量(或流值,flow value)为 (根据(3),它自然也等于 −  ),通常记为v 或v( f ) ,即
    0 [9 e2 q7 Q" r# K3 U& a% C5 [: S) J, i9 [# Q1 W
    / _. b: m% j+ U) v, _
    对这种单源单汇的网络,如果我们并不给定  和  (即流量不给定),则网络一 般记为 N = (s,t,V, A,U) 。最大流问题( maximum flow problem )就是在 N = (s,t,V, A,U) 中找到流值最大的可行流(即最大流)。我们将会看到,最大流问题 的许多算法也可以用来求解流量给定的网络中的可行流。也就是说,当我们解决了最大 流问题以后,对于在流量给定的网络中寻找可行流的问题,通常也就可以解决了。2 z# w/ @0 @/ B* D

    8 c. b' i( e) B' P5 `. h" j8 Q用线性规划描述最大流问题
    % K# j/ x! s: \1 _( W  w因此,用线性规划的方法,最大流问题可以形式地描述如下:
    ) t/ ~! `1 }8 J- b3 c
    % V2 e3 E: L) \% }% I! S, Y0 C6 r# u+ a

      E* [7 l2 p4 ]- Y: @定义】 如果一个矩阵 A 的任何子方阵的行列式的值都等于0,1或 −1,则称 A 是 全幺模的(totally unimodular TU,又译为全单位模的),或称 A 是全幺模矩阵。' J: m3 J; B! n' d: s9 J

    * u9 L, X1 ?. ?' y+ @, y整流定理
    ; u) o$ ~. h3 B9 A; j【定理 7】(整流定理) 最大流问题所对应的约束矩阵是全幺模矩阵。若所有弧容量 均为正整数,则问题的最优解为整数解。 最大流问题是一个特殊的线性规划问题。我们将会看到利用图的特点,解决这个问 题的方法较之线性规划的一般方法要方便、直观得多。
    6 v. J0 D  y3 ?( T/ u7 p- V. n$ {( o8 Q2 T7 o1 W9 {4 ^( z/ S
    1.3 单源和单汇运输网络" _; q, f; o, M' t
    多源多汇网络 转化成单源单汇网络
    4 L% S: t) K- T! X: M! T7 p实际问题往往是多源多汇网络,为了计算的规格化,可将多源多汇网络G 化成单 源单汇网络G' 。设 X 是G 的源,Y 是G 的汇,具体转化方法如下:; E# a4 P$ K' c
    0 ]" e0 H5 M( n% `) g! P- F
    (i)在原图G 中增加两个新的顶点 x 和 y ,令为新图G' 中之单源和单汇,则G 中 所有顶点V 成为G' 之中间顶点集。8 D/ O" a- a) Y+ j3 c
    . u0 k: t' i1 v7 U
    (ii)用一条容量为∞的弧把 x 连接到 X 中的每个顶点。% W* r" r& r$ e% E/ [; [0 G

    3 J! Q/ Q' |! C% Z: b(iii)用一条容量为∞的弧把Y 中的每个顶点连接到 y 。 G 和G' 中的流以一个简单的方式相互对应。若 f 是G 中的流,则由8 Q9 p) l3 y/ ]% R' B# \

      S9 R1 P/ W) [, \7 ^4 t4 p0 F
    * M# `9 D6 `, I- X( H7 E
    / {- |$ ~, P6 G2 最大流和最小割关系割的容量5 V' F9 i9 n' Z& d

    ) _- W( i* Q) W0 v! F7 J$ m$ d2 X+ h  K" @/ f8 y3 Q4 C+ _
    * _# j, j' z' W1 a
    则在这条可增广轨上每条前向弧的流都可以增加一个量δ ,而相应的后向弧的流可减 少δ ,这样就可使得网络的流量获得增加,同时可以使每条弧的流量不超过它的容量, 而且保持为正,也不影响其它弧的流量。总之,网络中 f 可增广轨的存在是有意义的, 因为这意味着 f 不是最大流。
    5 E$ R6 v" |3 t/ n0 m. A) Q, l
    1 k- A6 A" z  @4 I4 ^2 F3 最大流的一种算法—标号法7 i4 Q6 C( g- W8 C$ w8 H
    标号法是由 Ford 和 Fulkerson 在 1957 年提出的。用标号法寻求网络中最大流的基 本思想是寻找可增广轨,使网络的流量得到增加,直到最大为止。即首先给出一个初始 流,这样的流是存在的,例如零流。如果存在关于它的可增广轨,那么调整该轨上每条 弧上的流量,就可以得到新的流。对于新的流,如果仍存在可增广轨,则用同样的方法 使流的值增大,继续这个过程,直到网络中不存在关于新得到流的可增广轨为止,则该 流就是所求的最大流。
    3 ~- h& x' E8 P9 q; F
    1 F; c6 ^6 V# w. A, d( Q这种方法分为以下两个过程:: {3 _9 O, i" g0 d2 B' Z
    8 t, M) A" P2 g! h2 ?9 n
    A.标号过程:通过标号过程寻找一条可增广轨。# ~2 {2 o0 L' X; K: \+ a

    : I5 E! B# f; p- S4 QB.增流过程:沿着可增广轨增加网络的流量。0 S7 _' J8 L! s* T; G

    + {/ C0 y9 G" y0 Q这两个过程的步骤分述如下。
    2 s& |; P) }& c6 X6 T3 A& h
    3 a+ L: ^2 G% I" ^(A)标号过程:# _1 r$ j# r0 F& R9 O% `: {! m8 l

    % L% E5 l5 F. E! i8 l
    , p4 q& @4 {7 Q/ L( p
    + }) n7 E7 O3 \' r% ]. {(B)增流过程" k, @9 o& `& K& H
    4 {; H! e* k) |3 p  V
    网络最大流 x 的求解步骤: e" R5 g- n* Y. ^; ]1 w
    求网络 N = (s,t,V, A,U) 中的最大流 x 的算法的程序设计具体步骤如下:# c' I" G& {7 z7 |, d4 f# _

    + Z; }) j: p9 \- ~9 R对每个节点 j ,其标号包括两部分信息 (pred( j),maxf(j))
    3 Z& W& B9 N9 {  U# j) x. t) J  |1 h) l$ U
    该节点在可能的增广路中的前一个节点 pred( j) ,以及沿该可能的增广路到该节点为止 可以增广的最大流量 maxf( j)。
    + e. s( K0 K; l' [% c! ]" n/ Z% x% U2 p: J

    ' {: w  C; z/ Q3 r9 s1 l: m# L" D; K8 ~

    并将 j 加入 LIST 中。

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


    . _$ L' k2 ]: T5 d
    . _. K/ V; O$ M0 B, h1 H3 v, d% M- Z9 @7 E
    解 编写程序如下:9 X1 ?! M9 ]' j- n# p- q6 n' U

    : k% W' s( Y7 q% jclc,clear, ~' v$ N, Q) T: J. D
    u(1,2)=1;u(1,3)=1;u(1,4)=2;u(2,3)=1;u(2,5)=2;& t7 D) ~4 A" d; V! V) `& F
    u(3,5)=1;u(4,3)=3;u(4,5)=3;/ q2 X+ I- l$ u& E0 F: b
    f(1,2)=1;f(1,3)=0;f(1,4)=1;f(2,3)=0;f(2,5)=1;* j) K' Q2 i- S% r5 o
    f(3,5)=1;f(4,3)=1;f(4,5)=0;: \0 r; c4 L. y& C3 ^, s6 n0 }5 f
    n=length(u);list=[];maxf(n)=1;/ S; `" R5 {* M% T- w$ ~
    while maxf(n)>0
    ( ^" i& b0 S# jmaxf=zeros(1,n);pred=zeros(1,n);6 o, }* G) y" z' T
    list=1;record=list;maxf(1)=inf;' L/ u- c3 G/ |  X$ r
    % list是未检查邻接点的标号点,record是已标号点  ?. F6 o" a) J2 t( @
    while (~isempty(list))&(maxf(n)==0)
    1 q. I* d# d, R    flag=list(1);list(1)=[];
    . u2 W" e- m7 l9 ^2 E% O7 a    label1= find(u(flag,-f(flag,);  s* S0 X) v5 h* B
        label1=setdiff(label1,record);
    ! A* f3 C* L$ k2 ]  K# I. J    list=union(list,label1);) ?8 J# p" h& x: f- w- S6 |1 V
        pred(label1)=flag;1 b8 ~! N& ~0 |' y: P2 X! [5 z8 u
        maxf(label1)=min(maxf(flag),u(flag,label1)...
    ; c/ u4 |, C$ ^9 q    -f(flag,label1));
    - X1 Q% {! u9 S5 r" ]4 |    record=union(record,label1);1 U* q8 D; B+ x# H6 V
        label2=find(f(:,flag));0 V: E( H# r/ f3 e
        label2=label2';
    , `# @( O; a# J' G7 p2 m6 Z    label2=setdiff(label2,record);# A$ c; A0 b  ~6 Q+ H2 @
        list=union(list,label2);/ h3 c# |- Y9 |+ c: M* i. I, f& n
        pred(label2)=-flag;, h' Z7 `. D2 i( q% N1 k
        maxf(label2)=min(maxf(flag),f(label2,flag));
    # X. P0 s) M4 _( S; W+ n( r9 _6 H    record=union(record,label2);
    2 {) @0 p3 a  C$ L6 g+ r end
    1 ^; ~$ R; w4 d     if maxf(n)>09 @0 \# r. ?0 r2 o* m) O* m
            v2=n; v1=pred(v2);2 F# c4 x0 P, w! V& ^8 y, Y8 p
            while v2~=17 Q- W) u. {' P5 I3 f2 {
                if v1>0
    6 z1 n$ N/ U; g2 A, k7 W  r- q                f(v1,v2)=f(v1,v2)+maxf(n);, T  B2 \& D- K1 [
                else
    $ u: n  j  X( n$ i' M! w+ d3 @3 Z                v1=abs(v1);
    # t( g* ^6 o6 `5 I) p! Z                f(v2,v1)=f(v2,v1)-maxf(n);
    * H& d4 F) `$ I8 j2 H1 ?            end
      c8 q5 _; [3 z0 f9 w7 s7 i% L4 f            v2=v1; v1=pred(v2);! e$ ^& S- B; T+ @2 [) A- a7 ~
            end
    # `. K% Q( P) W9 I8 b: w; X6 ]    end" R7 f& i) s, _. m% S2 e' v
    end4 c9 p) g) Q* g8 S' V
    f
    - {9 I9 o' m( U7 E- T% k) o例18 现需要将城市 s 的石油通过管道运送到城市t ,中间有4个中转站  v1 ,v2 ,v3 和  v4 ,城市与中转站的连接以及管道的容量如图7所示,求从城市 s 到城市t 的最大流。- F) g6 D1 t, A- z6 _3 f
    - K% o: |* d* k, f
    - o' V  f1 i: `: j! E  M

    . \, Q! o! F) f  o5 f0 P, Q$ E% X" f# T; f  c
    解 使用最大流的数学规划表达式,编写LINGO程序如下:
    3 B: t% @, x; A5 K' c' w: j4 l$ o, a+ K9 d# V: c0 d4 v. r( I9 f
    model:2 ~9 Z  b/ j+ G3 j
    sets:0 c0 t) Q( Q1 f" m& ?* k
    nodes/s,1,2,3,4,t/;
    ) i4 G0 L# j; ?( c. y' K0 Q/ Rarcs(nodes,nodes)/s 1,s 3,1 2,1 3,2 3,2 t,3 4,4 2,4 t/:c,f;
    : R( \6 h4 N8 m: _" A6 _+ q4 Tendsets" ]. u; N2 J/ \* n* l1 L' e* M/ D
    data:
    ! u& B- Z: i1 D8 w1 \4 @& Q) N, z* \c=8 7 9 5 2 5 9 6 10;# O" y: P3 ?" N/ i% x' I3 D1 N
    enddata
      K: i1 Z& H5 M( Zn=@size(nodes); !顶点的个数;% ^' E6 y$ R* k" b
    max=flow;" s6 c  S. k% t
    @for(nodes(i)|i #ne#1 #and# i #ne# n:
    ( g* M# c; X0 O. _: o4 [* p' `    @sum(arcs(i,j):f(i,j))=@sum(arcs(j,i):f(j,i)
    8 g" _# X% Z$ z3 Z@sum(arcs(i,j)|i #eq# 1:f(i,j))=flow;! t4 b; m  Z& o" `3 h
    @sum(arcs(i,j)|j #eq# n:f(i,j))=flow;
    * V& C7 V' z6 D) H@for(arcsbnd(0,f,c));
    1 O+ m! `% p  U8 X( a7 @end , o, h6 n3 K4 X0 N0 y

    ) {+ v; {$ Q( I: ~& R0 e在上面的程序中,采用了稀疏集的编写方法。下面介绍的程序编写方法是利用赋权邻 接矩阵,这样可以不使用稀疏集的编写方法,更便于推广到复杂网络。
    2 V' u7 N; U- u; B1 ]) {) ?# g' x: U
    + F% ^$ o+ f  ?6 Ymodel:
    1 L- J- b9 @4 X3 e+ K) fsets:: x% B  B2 l- `: M1 N: J* K1 j$ M
    nodes/s,1,2,3,4,t/;
    8 H1 T$ w% t# ]/ E, Y& Yarcs(nodes,nodes):c,f;. a( Z$ @% f5 {; r- K4 a
    endsets/ d5 ?8 [" h7 X+ f  T3 q6 S9 @
    data:
    6 d3 \4 i' O! b5 a3 |: Bc=0;
    * x  h$ S" T! m4 W7 y% \@text('fdata.txt')=f;$ d4 G! s4 t. j9 @/ M& [! R( F
    enddata; C; p/ M* c# t, b' P, X5 s# e
    calc:7 [3 z/ `% A& |- ?4 k/ ]
    c(1,2)=8;c(1,4)=7;* Y" G' g( H& w/ a" F6 t! R
    c(2,3)=9;c(2,4)=5;! s/ O  K) ^1 ~1 A
    c(3,4)=2;c(3,6)=5;
    8 H5 b. I  A& Q1 G+ ac(4,5)=9;c(5,3)=6;c(5,6)=10;  I7 u& O$ x( L3 [" u- r1 T
    endcalc7 z+ M3 x. G3 S, `+ n- D; W
    n=@size(nodes); !顶点的个数;8 D! g8 Q0 H4 z! y" T, x6 V; y1 @
    max=flow;' o' b& U$ u. W& t7 r
    @for(nodes(i)|i #ne#1 #and# i #ne# n:
    / v4 w( I0 K  L" l    @sum(nodes(j):f(i,j))=@sum(nodes(j):f(j,i)));" W2 y0 o: Y& Q5 F
    @sum(nodes(i):f(1,i))=flow;
    ! o0 ?6 [# r3 g: Y" S& _@sum(nodes(i):f(i,n))=flow;) Y) E* i" Z; k; r2 f/ y7 t
    @for(arcsbnd(0,f,c));4 s2 J! S0 _2 c- t; R
    end
    4 s8 B) ?5 N' u+ L4 \4 H% c. G2 e% ~8 |+ k
    ————————————————
    0 F- W; k" i/ y5 H) v- y: [) o版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
      c# B1 E( I  t0 H$ x原文链接:https://blog.csdn.net/qq_29831163/article/details/89786313
    ) H' c: l) n" Z. e& t; Z' y& C
    3 L! L0 `6 }2 J: O' h  _0 Q" \& K6 v4 `% h# w0 G1 z# h) I
    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 21:30 , Processed in 0.343335 second(s), 51 queries .

    回顶部