QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1969|回复: 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 最大流问题的数学描述. ]0 h* y) I" _
    1.1 网络中的流 定义+ a% k! Q8 }9 U9 O2 o" M
    在以V 为节点集, A 为弧集的有向图G = (V, A) 上定义如下的权函数:
    8 S' n0 Q! f# A2 N6 F1 U
    7 H  f* w& d0 A! E6 n3 |. j(i) L : A → R 为孤上的权函数,弧 (i, j)∈ A 对应的权 L(i, j) 记为 ,称为孤 (i, j) 的容量下界(lower bound);$ L* |' {8 j2 F8 C: p
    7 A6 F% }+ B0 o9 l2 x
    (ii)U : A → R 为弧上的权函数,弧(i, j)∈ A对应的权U(i, j) 记为 ,称为孤 (i, j) 的容量上界或容量(capacity);
    % K5 x! M7 n4 h8 l
    & X" g" ]4 M; h, n+ Q/ q(iii) D :V → R 为顶点上的权函数,节点i ∈V 对应的权 D(i) 记为  ,称为顶 点i 的供需量(supply/demand);3 _) o; N, \+ U- d) x' j
    0 ]6 S! B4 h9 m# u
    此时所构成的网络称为流网络,可以记为 N = (V, A, L,U,D) 。 由于我们只讨论V, A 为有限集合的情况,所以对于弧上的权函数 L,U 和顶点上的 权函数 D ,可以直接用所有孤上对应的权和顶点上的权组成的有限维向量表示,因此 L,U, D 有时直接称为权向量,或简称权。由于给定有向图G = (V, A) 后,我们总是可 以在它的弧集合和顶点集合上定义各种权函数,所以流网络一般也直接简称为网络。  e+ q& ~. Y3 Y4 g
    $ x! G. P4 P* m: ^, z: z. g$ B* j2 w
    在流网络中,弧(i, j) 的容量下界  和容量上界表示的物理意义分别是:通过该 弧发送某种“物质”时,必须发送的最小数量为 ,而发送的最大数量为 。顶点i ∈V 对应的供需量则表示该顶点从网络外部获得的“物质”数量( > 0时),或从该顶 点发送到网络外部的“物质”数量(< 0 时)。下面我们给出严格定义。% K% h! D# L6 i
    + L; g& ^; h3 t/ k0 U6 c% K
    可行流(feasible flow)
    % F- J8 P! H# z/ N/ p8 T, ]* G* x3 [  L/ u* z) b9 T
    / i2 i( n% P  G- Z# F1 y
    * E) D  C% B+ {# z+ J
    + A; r, ~* m0 Y& H: e
    可见,当 di > 0时,表示有di 个单位的流量从网络外部流入该顶点,因此顶点i 称 为供应点(supply node)或源(source),有时也形象地称为起始点或发点等;当di < 0 时,表示有|di | 个单位的流量从该顶点流失到网络外部(或说被该顶点吸收),因此顶 点i 称为需求点(demand node)或汇(sink),有时也形象地称为终止点或收点等;当 di = 0时,顶点i 称为转运点(transshipment node)或平衡点、中间点等。此外,根据 (1)可知,对于可行网络,必有" T, G0 c) Q1 d* P+ F# E

    8 U8 Z! \5 T' C. t: ]: k9 z0 C# @* {7 e

    & p, t& u' K! p; I' |也就是说,所有节点上的供需量之和为 0 是网络中存在可行流的必要条件
    % w. N6 ^2 j5 l% \/ x6 r
    , J' U( H2 L; \* Z
    3 K6 b7 P. y, h9 c4 H; R1 K0 O6 Z( |4 H( x) J$ P+ c8 K2 V/ Q; p

    & W- v! v: v4 l1 z1.2 最大流问题: D: a2 s6 K& X2 @
    考虑如下流网络 N = (V, A,U,D):节点 s 为网络中唯一的源点,t 为唯一的汇点, 而其它节点为转运点。如果网络中存在可行流 f ,此时称流 f 的流量(或流值,flow value)为 (根据(3),它自然也等于 −  ),通常记为v 或v( f ) ,即
    1 i; t6 V/ P9 e% f
    . ^+ h" K6 I: g* x1 l+ \* D
    + X( b7 U% D- ~* B对这种单源单汇的网络,如果我们并不给定  和  (即流量不给定),则网络一 般记为 N = (s,t,V, A,U) 。最大流问题( maximum flow problem )就是在 N = (s,t,V, A,U) 中找到流值最大的可行流(即最大流)。我们将会看到,最大流问题 的许多算法也可以用来求解流量给定的网络中的可行流。也就是说,当我们解决了最大 流问题以后,对于在流量给定的网络中寻找可行流的问题,通常也就可以解决了。$ D; t) \8 v4 P; X2 F  H
    , }; g) s$ E4 {  f) a
    用线性规划描述最大流问题" v9 B1 W$ s$ l6 U5 i5 b, Q% W8 Q  K
    因此,用线性规划的方法,最大流问题可以形式地描述如下:+ v- `  T* |  `1 F& K( l* v& s
    / e3 i* I$ Z! o, I4 U' |6 f# A

    4 p2 S' t& v7 u1 {) `+ M& }
    8 I' t% l$ G( X4 x定义】 如果一个矩阵 A 的任何子方阵的行列式的值都等于0,1或 −1,则称 A 是 全幺模的(totally unimodular TU,又译为全单位模的),或称 A 是全幺模矩阵。
    " p3 N. H8 }% l; H1 B
    ( S+ q/ O% c& ^0 T4 B整流定理; {, C5 ]6 I  Q* n
    【定理 7】(整流定理) 最大流问题所对应的约束矩阵是全幺模矩阵。若所有弧容量 均为正整数,则问题的最优解为整数解。 最大流问题是一个特殊的线性规划问题。我们将会看到利用图的特点,解决这个问 题的方法较之线性规划的一般方法要方便、直观得多。
    9 [7 ~& E% J$ ^1 B
    + {7 J) K* D+ H. n1.3 单源和单汇运输网络
      N* n" |3 _9 w7 f  a2 j( [( _多源多汇网络 转化成单源单汇网络5 r2 }, Z* Q+ L! X  {
    实际问题往往是多源多汇网络,为了计算的规格化,可将多源多汇网络G 化成单 源单汇网络G' 。设 X 是G 的源,Y 是G 的汇,具体转化方法如下:' v& c  p7 L$ u& m1 s6 p7 J; A

    5 G2 o1 N6 {  @' a* P- E+ d(i)在原图G 中增加两个新的顶点 x 和 y ,令为新图G' 中之单源和单汇,则G 中 所有顶点V 成为G' 之中间顶点集。3 ]! W& V1 y  S# r% z* k. Q
    9 l; q7 w- _( [/ l9 p
    (ii)用一条容量为∞的弧把 x 连接到 X 中的每个顶点。! O: b- d$ V4 j" g2 b

    $ R0 R; p4 w/ M; k(iii)用一条容量为∞的弧把Y 中的每个顶点连接到 y 。 G 和G' 中的流以一个简单的方式相互对应。若 f 是G 中的流,则由3 |' {" z! w# S: K: o
    6 o* ^' c+ h  [- t
    * v/ j# V" d/ T

    ) S4 V- U* J2 e4 C/ J7 O2 最大流和最小割关系割的容量( r3 e# s% w+ e# V
    ) a& p- f  g' ?/ o) r; j) u

    # T  K, r- [2 J, ^' q3 }
    1 w* ]! _+ B" o+ a  v- r! Z则在这条可增广轨上每条前向弧的流都可以增加一个量δ ,而相应的后向弧的流可减 少δ ,这样就可使得网络的流量获得增加,同时可以使每条弧的流量不超过它的容量, 而且保持为正,也不影响其它弧的流量。总之,网络中 f 可增广轨的存在是有意义的, 因为这意味着 f 不是最大流。- o6 W0 V- H$ i

    0 j$ V) v$ \$ @- o/ K$ @+ L$ t3 最大流的一种算法—标号法* w* ?' y4 t% g% k$ X+ `" F( {& c
    标号法是由 Ford 和 Fulkerson 在 1957 年提出的。用标号法寻求网络中最大流的基 本思想是寻找可增广轨,使网络的流量得到增加,直到最大为止。即首先给出一个初始 流,这样的流是存在的,例如零流。如果存在关于它的可增广轨,那么调整该轨上每条 弧上的流量,就可以得到新的流。对于新的流,如果仍存在可增广轨,则用同样的方法 使流的值增大,继续这个过程,直到网络中不存在关于新得到流的可增广轨为止,则该 流就是所求的最大流。
    + e' N5 O1 k& p6 q, Y: r, T# C4 U3 I0 |/ Z4 G
    这种方法分为以下两个过程:7 i. j$ V+ i- W' T0 R" x
    4 J9 I* t& L9 f6 v
    A.标号过程:通过标号过程寻找一条可增广轨。
    2 f) M4 q4 a) A: W, J3 u/ _1 _* Y* g
    B.增流过程:沿着可增广轨增加网络的流量。; q' @5 e0 s" L3 J
    7 B) n& h! W- F+ _6 L+ z* q: ^3 V
    这两个过程的步骤分述如下。% w# @: M8 @! X  w

    1 }; x% {+ S: `! ?* ?, T( k(A)标号过程:
    9 m7 T$ G3 a- j' E- e; d$ r* ?  J
    8 l6 t! P) ^' ^1 z! t) W+ e/ s8 X/ K: {" B4 b( t; l

    ) K, p" W0 f7 ^(B)增流过程1 B3 l/ v  `$ z8 v. j3 \

    # d& }1 X9 H; }. n8 f1 }2 G9 K网络最大流 x 的求解步骤
    ! i( m* Q! U2 M: v) A  }+ Y求网络 N = (s,t,V, A,U) 中的最大流 x 的算法的程序设计具体步骤如下:) z# s, _/ V6 X: @$ F) D$ {7 |. o4 a1 |

    ! Y- ^) y3 b9 k% _" [对每个节点 j ,其标号包括两部分信息 (pred( j),maxf(j))8 l2 [( b, X5 {+ J; a
    8 L6 f' e$ ^: ~- f* h) g0 p) h
    该节点在可能的增广路中的前一个节点 pred( j) ,以及沿该可能的增广路到该节点为止 可以增广的最大流量 maxf( j)。4 i8 y% }" I, J$ }# g; Q! j

    & \7 V/ z- s1 T3 Y5 l$ b* A5 a1 ^7 ?3 ^: ~! \& g* G! N
    ! c" P4 x6 C' ~: p# J7 i

    并将 j 加入 LIST 中。

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


    ! a) m. j! z4 P  ]& U% w+ n( i* T6 c
    # F' ?& m8 O0 J3 X8 E/ {: [9 N4 q( Y! Q) I7 u! N* v
    解 编写程序如下:
    , [2 S2 y7 A1 {0 t# c) E# ?
    1 b( `4 W2 t2 `* m4 rclc,clear
    ; z3 j5 Y% M2 d" C0 hu(1,2)=1;u(1,3)=1;u(1,4)=2;u(2,3)=1;u(2,5)=2;
    - `  _$ ?. T# Xu(3,5)=1;u(4,3)=3;u(4,5)=3;7 k: b2 Z* Q9 f% i9 o5 |
    f(1,2)=1;f(1,3)=0;f(1,4)=1;f(2,3)=0;f(2,5)=1;
    / E( L# t$ Z: N+ rf(3,5)=1;f(4,3)=1;f(4,5)=0;0 P8 e9 L) U2 Z" g
    n=length(u);list=[];maxf(n)=1;+ u' x8 u5 S6 ~( c
    while maxf(n)>0
    4 H% g: ~1 V# \. Bmaxf=zeros(1,n);pred=zeros(1,n);
    4 A: [* E! k1 w! b1 J; q3 I. ^% Vlist=1;record=list;maxf(1)=inf;
    # {; _" n" V3 T- i1 i % list是未检查邻接点的标号点,record是已标号点
    ' n+ a8 ^8 u" D4 z$ pwhile (~isempty(list))&(maxf(n)==0)) t/ s& t/ l8 H" b4 @
        flag=list(1);list(1)=[];! s1 C7 k7 @( T. K- x
        label1= find(u(flag,-f(flag,);
    , p0 `0 N! w5 s    label1=setdiff(label1,record);, A0 U& T! s3 H
        list=union(list,label1);' x' s7 y( g3 p1 y. D
        pred(label1)=flag;/ x$ _, N* g, a: g/ \# {/ ~
        maxf(label1)=min(maxf(flag),u(flag,label1)...
    6 w8 G6 E( H, t5 A    -f(flag,label1));; k$ n$ Z, g0 x* M# H
        record=union(record,label1);( p6 W# F* `: \/ d9 o' q: B' ]6 c
        label2=find(f(:,flag));/ a7 @; }8 L9 x5 w; ~  m# C
        label2=label2';4 j% s# [5 A# b5 Z
        label2=setdiff(label2,record);  V2 k, ?& K. T4 O+ B
        list=union(list,label2);
    ! g. V' _$ U5 X* Z1 h  k    pred(label2)=-flag;
    6 i0 H# L" R* A* q7 N    maxf(label2)=min(maxf(flag),f(label2,flag));
    * B; [* v9 r3 S8 I$ b! d+ h2 p    record=union(record,label2);8 n& b" t* v6 {2 x$ R# B8 a. E
    end7 G( H2 ]9 H" O) i3 C: W
         if maxf(n)>0
      l. E/ t( D: l- P" h% @# X' Y6 ~& q7 O        v2=n; v1=pred(v2);) {% r. m: H0 p' U& U/ L: `
            while v2~=1
    " o6 H5 v- I! D& n  ~( z( @            if v1>08 I3 Y  z6 A4 _7 ^9 N# u; h2 r
                    f(v1,v2)=f(v1,v2)+maxf(n);7 d) C# d5 S8 e* n, r7 E5 w
                else
    ( Q7 a! o& [& _. o                v1=abs(v1);* _7 _6 ~& a/ d$ g3 `# C
                    f(v2,v1)=f(v2,v1)-maxf(n);+ a1 j# G4 h# j+ A! X
                end
    : y& s0 Q& u! Q9 k/ S            v2=v1; v1=pred(v2);& c& g# \$ K1 ~% a5 P! a0 p& F7 [9 S
            end
    : W5 a! z, d7 u/ T# p5 l$ f8 r% ^$ U    end
    ' V* F# S- L) l. Q& o( t5 I9 aend
    2 W- N" ]2 l* g7 l5 y# e7 ~) ?f
      H) h7 T: ~7 d# H例18 现需要将城市 s 的石油通过管道运送到城市t ,中间有4个中转站  v1 ,v2 ,v3 和  v4 ,城市与中转站的连接以及管道的容量如图7所示,求从城市 s 到城市t 的最大流。; N- n- G% A& G8 \
    + v$ \* ?8 ~9 F) ~0 a, X9 X
    + P! s& Y/ h" ^  r' Z$ Y/ Q7 t

    % W4 m, s; ~) k8 y( ~1 h. ?+ W9 w* f; {* \9 }0 G0 H
    解 使用最大流的数学规划表达式,编写LINGO程序如下:
    1 K/ b1 O0 h$ x8 m3 Y! [/ c. I' g& S1 g. p/ O9 _$ [
    model:; g  H- i; }6 l/ Z& h( T( j
    sets:7 L" J8 Z- q  x7 B4 L" l+ S  d
    nodes/s,1,2,3,4,t/;) Y2 x7 A, B9 ^7 ~6 j' f5 B
    arcs(nodes,nodes)/s 1,s 3,1 2,1 3,2 3,2 t,3 4,4 2,4 t/:c,f;4 h0 o# s2 R) ?
    endsets! |1 f; V2 `3 L* }& M
    data:
    8 A7 q2 S4 p8 r% Z$ d8 nc=8 7 9 5 2 5 9 6 10;2 Q4 l* f& G/ p4 ]* V" d& S- v
    enddata6 h" y! E2 _' E+ x
    n=@size(nodes); !顶点的个数;
    3 k- i' D- o4 {( E+ Omax=flow;
    8 ?: C3 ]; |! S2 I6 z@for(nodes(i)|i #ne#1 #and# i #ne# n:
    % P) l9 i5 [- |) t9 t* M    @sum(arcs(i,j):f(i,j))=@sum(arcs(j,i):f(j,i)5 I- J8 z! u, ?6 s6 g5 M' K
    @sum(arcs(i,j)|i #eq# 1:f(i,j))=flow;# M4 v% O/ f# D# z4 N8 h, U. [/ f
    @sum(arcs(i,j)|j #eq# n:f(i,j))=flow;
    7 g6 Q# W4 j7 v* a' S& c@for(arcsbnd(0,f,c));' Q1 b( ~. Y1 H0 N  s6 Q( m
    end
    9 ]) H% t1 u4 q2 v1 d
    & s6 I! q6 \- i0 c0 [8 G$ Q0 V/ D在上面的程序中,采用了稀疏集的编写方法。下面介绍的程序编写方法是利用赋权邻 接矩阵,这样可以不使用稀疏集的编写方法,更便于推广到复杂网络。
    $ I& E0 ]1 ?; d1 o: d& S* [& p; {; _7 a
    model:. R$ E: K# B( F% G
    sets:6 M' G1 z% G) G( |, Z" Z
    nodes/s,1,2,3,4,t/;
    $ {$ Y! C8 _( G  F7 Varcs(nodes,nodes):c,f;9 j9 h+ `; q6 Z6 x1 ~
    endsets% o* t* Q: \* g# ?( C, E: O
    data:
    6 P4 g3 s! x* ~9 P! T. d. vc=0;- ~9 Y7 n7 k" ?/ P; `4 x, k
    @text('fdata.txt')=f;
    % s3 W1 ~8 a. b5 @- tenddata+ `( v/ j% F/ [: e  D
    calc:
    4 F2 c, W' N+ y9 j! b, hc(1,2)=8;c(1,4)=7;
    2 T) n- M0 n: ic(2,3)=9;c(2,4)=5;
    % K+ k! K% a3 ^! S. l7 W# Bc(3,4)=2;c(3,6)=5;& y- @# Q" |# c
    c(4,5)=9;c(5,3)=6;c(5,6)=10;- g% J: s! Y* ?3 c* g
    endcalc+ d2 i: m) o# S3 `6 x% {; V
    n=@size(nodes); !顶点的个数;, R. ~1 M' E# P  }( X
    max=flow;; a$ H4 I+ L4 C2 P4 {
    @for(nodes(i)|i #ne#1 #and# i #ne# n:6 ?! b8 d4 c% s1 `! }
        @sum(nodes(j):f(i,j))=@sum(nodes(j):f(j,i)));
    * o; `! l6 a8 A8 O- G4 x@sum(nodes(i):f(1,i))=flow;- N. K* v% ?# z: W& P& D6 j2 o
    @sum(nodes(i):f(i,n))=flow;( P5 S- w) i3 @) z* [( E! o( z- K: ~4 @
    @for(arcsbnd(0,f,c));, R) W4 F" h, x
    end" `) s  x5 q* w! ^
    + [  k1 t0 E- k
    ————————————————
    - i% _+ _" V9 E  M版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。' |6 D- ?$ x( O7 M$ ~9 r' |: K
    原文链接:https://blog.csdn.net/qq_29831163/article/details/89786313
    + P, F$ l7 H6 |4 S- A% C+ ~; v$ s! ^1 @* c, C8 t. O" c5 H5 J

    2 O4 u% f* Y. [0 R5 M8 t
    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-9 20:04 , Processed in 0.636827 second(s), 50 queries .

    回顶部