QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1968|回复: 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 最大流问题的数学描述3 r" T; M# d$ @, q- H
    1.1 网络中的流 定义
    * z. @$ ^/ D+ N1 w$ n在以V 为节点集, A 为弧集的有向图G = (V, A) 上定义如下的权函数:1 ]0 I6 }6 e( x: a! W4 _3 Z

    / F! z) B5 j7 H: y(i) L : A → R 为孤上的权函数,弧 (i, j)∈ A 对应的权 L(i, j) 记为 ,称为孤 (i, j) 的容量下界(lower bound);
    6 ^( u$ d" G$ y; O
    $ }' D& [% X9 A$ w9 @& U+ b(ii)U : A → R 为弧上的权函数,弧(i, j)∈ A对应的权U(i, j) 记为 ,称为孤 (i, j) 的容量上界或容量(capacity);
    - ]( W$ j. T1 `* H4 N- ^! v2 h! w: w) f; B
    (iii) D :V → R 为顶点上的权函数,节点i ∈V 对应的权 D(i) 记为  ,称为顶 点i 的供需量(supply/demand);! r" m' D# S+ K6 V2 W
    ) w: W- R9 p, A3 x/ a: Z
    此时所构成的网络称为流网络,可以记为 N = (V, A, L,U,D) 。 由于我们只讨论V, A 为有限集合的情况,所以对于弧上的权函数 L,U 和顶点上的 权函数 D ,可以直接用所有孤上对应的权和顶点上的权组成的有限维向量表示,因此 L,U, D 有时直接称为权向量,或简称权。由于给定有向图G = (V, A) 后,我们总是可 以在它的弧集合和顶点集合上定义各种权函数,所以流网络一般也直接简称为网络。
    - b% ~( e4 ?8 x2 E0 X. e9 X! t- ^4 Q$ g
    5 E0 a* w* U6 B/ C在流网络中,弧(i, j) 的容量下界  和容量上界表示的物理意义分别是:通过该 弧发送某种“物质”时,必须发送的最小数量为 ,而发送的最大数量为 。顶点i ∈V 对应的供需量则表示该顶点从网络外部获得的“物质”数量( > 0时),或从该顶 点发送到网络外部的“物质”数量(< 0 时)。下面我们给出严格定义。$ ?& U0 o' e) X! ~, J5 m! @

    1 n! M  X+ d' x7 n/ V9 _可行流(feasible flow)- |1 v" k* f! l

    9 t( y/ m7 ~& x- h. ?& u& g4 q3 }( C! T% e5 e1 Q
    ; [# b7 s/ a/ G$ A
    0 c& I+ Y5 d/ K
    可见,当 di > 0时,表示有di 个单位的流量从网络外部流入该顶点,因此顶点i 称 为供应点(supply node)或源(source),有时也形象地称为起始点或发点等;当di < 0 时,表示有|di | 个单位的流量从该顶点流失到网络外部(或说被该顶点吸收),因此顶 点i 称为需求点(demand node)或汇(sink),有时也形象地称为终止点或收点等;当 di = 0时,顶点i 称为转运点(transshipment node)或平衡点、中间点等。此外,根据 (1)可知,对于可行网络,必有
    % g5 R5 J  _4 ?' ^* I- G+ w) d' a4 V/ ?& n  D) c

    & }  C( r+ ?# m5 Z& ~
    6 ]3 A$ R1 y( B0 a. E: I- H也就是说,所有节点上的供需量之和为 0 是网络中存在可行流的必要条件
    9 m, W% a; ^' s( ~. @  E. w
    ) x- i) ?* ^- T4 `/ S# o8 u, z3 D: ^. W) z1 P. w2 n0 ~$ W6 D* V
    + X9 y8 Y, W0 e3 B
    % P) c& z- G9 ~* p
    1.2 最大流问题4 O/ _. G- T1 M6 g7 G  f% L
    考虑如下流网络 N = (V, A,U,D):节点 s 为网络中唯一的源点,t 为唯一的汇点, 而其它节点为转运点。如果网络中存在可行流 f ,此时称流 f 的流量(或流值,flow value)为 (根据(3),它自然也等于 −  ),通常记为v 或v( f ) ,即9 q" m6 d' T+ K. ^

    3 ?4 F* ^2 X5 [" F$ X+ p' X1 @) w  y3 B0 M; _' ^
    对这种单源单汇的网络,如果我们并不给定  和  (即流量不给定),则网络一 般记为 N = (s,t,V, A,U) 。最大流问题( maximum flow problem )就是在 N = (s,t,V, A,U) 中找到流值最大的可行流(即最大流)。我们将会看到,最大流问题 的许多算法也可以用来求解流量给定的网络中的可行流。也就是说,当我们解决了最大 流问题以后,对于在流量给定的网络中寻找可行流的问题,通常也就可以解决了。
    " V2 N! n8 Z) P5 P8 Z
    * B# x1 Q+ [( B2 U# o/ {用线性规划描述最大流问题& b5 N7 i4 ^7 V" a) t: y
    因此,用线性规划的方法,最大流问题可以形式地描述如下:; \' t/ ~4 P% G- r6 I/ b
    % x$ d! d. {5 d3 I9 J2 G% u0 K. d& `
    ; Z# o% _3 m& z
    6 h# x3 G8 @$ J9 Z+ _
    定义】 如果一个矩阵 A 的任何子方阵的行列式的值都等于0,1或 −1,则称 A 是 全幺模的(totally unimodular TU,又译为全单位模的),或称 A 是全幺模矩阵。
    & N9 [" v' W2 [6 p3 U9 e( z' C; _
    整流定理
    5 j! ?" |) l' ]& [【定理 7】(整流定理) 最大流问题所对应的约束矩阵是全幺模矩阵。若所有弧容量 均为正整数,则问题的最优解为整数解。 最大流问题是一个特殊的线性规划问题。我们将会看到利用图的特点,解决这个问 题的方法较之线性规划的一般方法要方便、直观得多。
    ; X6 e2 @; P$ C0 C
    ' A6 S, G3 j8 H) A1.3 单源和单汇运输网络. _' q: p. z  A/ Y2 z( X( o
    多源多汇网络 转化成单源单汇网络2 e: G- o$ H2 k& ~7 d& X% D
    实际问题往往是多源多汇网络,为了计算的规格化,可将多源多汇网络G 化成单 源单汇网络G' 。设 X 是G 的源,Y 是G 的汇,具体转化方法如下:
    & y2 ^4 X4 O: F5 h; x' ^% c! E
      p: M' j- C, v( m5 r# Q(i)在原图G 中增加两个新的顶点 x 和 y ,令为新图G' 中之单源和单汇,则G 中 所有顶点V 成为G' 之中间顶点集。
    6 {: Y' @* G9 }, [  G
    # v6 e. V3 ]8 \5 z(ii)用一条容量为∞的弧把 x 连接到 X 中的每个顶点。; J# t& c9 l/ ?# a+ q" \. W& k

    % ^0 J  H: _' J(iii)用一条容量为∞的弧把Y 中的每个顶点连接到 y 。 G 和G' 中的流以一个简单的方式相互对应。若 f 是G 中的流,则由
    5 C7 M) _3 u/ D1 l; c- n3 C$ N' T
    & M0 w. |; `( Q% F, ~6 Z" X' C4 z) F' [! e2 G" k! g

    # T; T- P/ X! q, M7 C2 最大流和最小割关系割的容量9 F8 G; G4 N) x2 D# ~! N
    6 y4 v, z" Y0 b6 T5 h2 M
    % I& L+ s3 F6 z5 G$ x! Y
    / H0 V: ~5 H4 g) i) n
    则在这条可增广轨上每条前向弧的流都可以增加一个量δ ,而相应的后向弧的流可减 少δ ,这样就可使得网络的流量获得增加,同时可以使每条弧的流量不超过它的容量, 而且保持为正,也不影响其它弧的流量。总之,网络中 f 可增广轨的存在是有意义的, 因为这意味着 f 不是最大流。0 p9 ], Z7 h; b7 {, ]: Z

    " C! y( b% F. s3 l3 最大流的一种算法—标号法( M& u8 t- `& y; T6 {
    标号法是由 Ford 和 Fulkerson 在 1957 年提出的。用标号法寻求网络中最大流的基 本思想是寻找可增广轨,使网络的流量得到增加,直到最大为止。即首先给出一个初始 流,这样的流是存在的,例如零流。如果存在关于它的可增广轨,那么调整该轨上每条 弧上的流量,就可以得到新的流。对于新的流,如果仍存在可增广轨,则用同样的方法 使流的值增大,继续这个过程,直到网络中不存在关于新得到流的可增广轨为止,则该 流就是所求的最大流。. {2 ?" {/ w* G: B/ w

    ) X4 @6 O, u8 o8 M5 P这种方法分为以下两个过程:
    * c2 K- p! ^+ M
    - N1 z2 a) I# `" d. b  ~A.标号过程:通过标号过程寻找一条可增广轨。
    ' {# ^% [8 W5 U, Z. O
    . H( r. n( u$ K4 E9 DB.增流过程:沿着可增广轨增加网络的流量。3 ]# y' T( z, E0 Z1 e+ a0 g1 c( l
    # `6 J! p. o, p2 M, t; T* H$ S8 Y
    这两个过程的步骤分述如下。
    5 Z' e. G) `" r0 A: y" ~! E
    ) x5 C0 g/ G3 g* w- @(A)标号过程:# g9 _+ T/ Q9 g: ?: ^; M4 r

    + k2 i' ~, P* g  }8 D. q0 r2 i9 \& @8 b) C% p$ G

    8 G; Q4 O0 C5 @(B)增流过程
    * W5 \% v% {/ ]  o
    5 u9 b# q& u/ ?, n) T% A网络最大流 x 的求解步骤  s0 X4 b. `! y( D+ z
    求网络 N = (s,t,V, A,U) 中的最大流 x 的算法的程序设计具体步骤如下:# q: T+ _" P0 `9 |
    - M4 y3 E; D* j: W5 q' o4 W
    对每个节点 j ,其标号包括两部分信息 (pred( j),maxf(j))3 @* x* \! M8 @  N. F

    7 @7 |' k+ M, \2 E/ y: l该节点在可能的增广路中的前一个节点 pred( j) ,以及沿该可能的增广路到该节点为止 可以增广的最大流量 maxf( j)。
    - M5 e% x% G/ L& F+ G$ a/ D& L0 m1 D8 i
    8 U8 R. u  O8 y% v+ L7 F

    9 ]2 a* T" j5 E" k

    并将 j 加入 LIST 中。

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

    ( L7 X# m7 @# `% a: B! r1 H) u
    . ^! t/ X5 O0 c' R; l5 ?& I
    5 z* c: q; K8 [% H
    解 编写程序如下:  h6 v9 `( K& d  o2 L( n! u
    * s% @0 K2 k/ W" [
    clc,clear7 q5 n! P! x7 n# D" V0 w8 ?1 F
    u(1,2)=1;u(1,3)=1;u(1,4)=2;u(2,3)=1;u(2,5)=2;, m+ e# u0 n' L; d9 _
    u(3,5)=1;u(4,3)=3;u(4,5)=3;% N8 |8 k& G8 P* m; k& M
    f(1,2)=1;f(1,3)=0;f(1,4)=1;f(2,3)=0;f(2,5)=1;; K7 Q4 g! E. m, W. q8 j0 o1 h
    f(3,5)=1;f(4,3)=1;f(4,5)=0;: y# a0 h. }1 ]/ J% p- v
    n=length(u);list=[];maxf(n)=1;
    . a! g# q+ E7 o5 vwhile maxf(n)>0. O4 J) ?% e% s/ \
    maxf=zeros(1,n);pred=zeros(1,n);- C+ r8 l/ B1 m+ f( P% R
    list=1;record=list;maxf(1)=inf;
    " l% S* D( T# @& ~$ A % list是未检查邻接点的标号点,record是已标号点3 S+ ]8 ~4 s7 z' L2 O4 j
    while (~isempty(list))&(maxf(n)==0)2 Y' o* i- B4 q/ Y0 @0 W
        flag=list(1);list(1)=[];5 }7 p$ F6 O, I) j1 d
        label1= find(u(flag,-f(flag,);+ G* M8 F3 D/ j- U/ P! m$ a" ^
        label1=setdiff(label1,record);# n# D4 {0 w- ]
        list=union(list,label1);
    9 o! W+ p9 e. i    pred(label1)=flag;8 W  w7 u  ~4 P. Z0 B3 h
        maxf(label1)=min(maxf(flag),u(flag,label1)...
    4 y' r' L: c; H; F3 E    -f(flag,label1));; I- O- G( }  I4 l
        record=union(record,label1);- h/ h( l1 c5 m) ^* N1 ]0 S) b
        label2=find(f(:,flag));
    " S7 u( T& h. h/ }% z& |; b    label2=label2';* X. Q$ i1 z# b, z' l0 V8 V( `  F' G
        label2=setdiff(label2,record);! f8 q( T% k9 i, {
        list=union(list,label2);
    % K+ w, `4 K/ C& W5 D" }4 J* I' o    pred(label2)=-flag;" _  ]1 w1 q; W3 ~/ |
        maxf(label2)=min(maxf(flag),f(label2,flag));
    * u' o  `8 h) C' l    record=union(record,label2);
    ) u0 T2 ^8 _4 V- ?" f end
    ) D# v7 O, E7 }& V% S7 g7 {1 p     if maxf(n)>0
    7 h5 Y5 v& f/ T9 g  b5 ~        v2=n; v1=pred(v2);
    - n: u) F9 ^* b! m4 O        while v2~=1. l/ B0 v. ~+ ^0 |- N1 e5 j$ x2 ~+ e
                if v1>0
    8 T. k0 @( |* x8 y% ^                f(v1,v2)=f(v1,v2)+maxf(n);
    : M# r/ H$ o" t% j- P2 F. ~            else  {7 h: G5 z. c; z% {; ?! \6 P
                    v1=abs(v1);9 x* Y% n8 s& [, ?  z, }
                    f(v2,v1)=f(v2,v1)-maxf(n);
    & T  Z( t2 d* o, e# F6 F/ ^            end
    * W/ ^+ |3 u9 F) D# ~6 D" I8 h  E$ X5 P            v2=v1; v1=pred(v2);/ e* v+ B# u* c- k+ H9 s$ \/ t
            end5 T) h. j; V9 u& z$ V# v9 P
        end
    5 @1 H9 Z& |/ j7 Nend, W- Z. Z2 K. B$ H' a/ J+ K# u7 n, K
    f ; I. B4 o0 w9 _* X) L( ?
    例18 现需要将城市 s 的石油通过管道运送到城市t ,中间有4个中转站  v1 ,v2 ,v3 和  v4 ,城市与中转站的连接以及管道的容量如图7所示,求从城市 s 到城市t 的最大流。
    ( s4 y2 ~. J& ]5 S- U- B( F8 u" |2 ^
    5 l8 g% c2 l/ f! _) s( T4 ]

    $ C1 ^. r) {$ G6 n
    1 v; k0 D- Y- Q" D& n' |9 ?解 使用最大流的数学规划表达式,编写LINGO程序如下:" r( V9 t' ]: `5 D2 Z4 Z4 Y" C

    $ F1 O5 ?# H9 a( U$ K" G2 jmodel:
    # ^3 Y$ R7 q6 @sets:
    9 w. S3 r; H) G$ q0 x) qnodes/s,1,2,3,4,t/;
    2 k3 @% @' `3 k2 h5 oarcs(nodes,nodes)/s 1,s 3,1 2,1 3,2 3,2 t,3 4,4 2,4 t/:c,f;  y# h: i  i. L& p1 k
    endsets
    # q  Q4 l, ]/ f6 @( p  Adata:
    , N- y- c2 D/ Lc=8 7 9 5 2 5 9 6 10;
    2 p9 B; y1 T! a0 E6 ]# C% S; Qenddata+ s* V+ V- y. l, f- g. j. c; A
    n=@size(nodes); !顶点的个数;0 K% B" h/ g7 g" G5 {
    max=flow;5 I& k1 V( [8 Q# ~9 M: _- H$ A2 S: ]
    @for(nodes(i)|i #ne#1 #and# i #ne# n:- U4 L$ B- [9 S5 ], I- l
        @sum(arcs(i,j):f(i,j))=@sum(arcs(j,i):f(j,i)
    2 a+ ~+ [5 D) _. L@sum(arcs(i,j)|i #eq# 1:f(i,j))=flow;
    $ [( Y8 ?. G8 {! O@sum(arcs(i,j)|j #eq# n:f(i,j))=flow;# Z8 F/ b  @+ @8 T! }, M7 v
    @for(arcsbnd(0,f,c));
    ) N+ e' t& G) Send 4 J( X+ ^  V7 f/ K6 E! G  H
    ! F( |- n" w( a# Y
    在上面的程序中,采用了稀疏集的编写方法。下面介绍的程序编写方法是利用赋权邻 接矩阵,这样可以不使用稀疏集的编写方法,更便于推广到复杂网络。, B+ w5 y2 B: A0 G/ D) ~

    2 g+ {+ L% x$ Z7 smodel:4 M& l8 v$ v  P0 q
    sets:9 d$ s3 z6 k! R; J
    nodes/s,1,2,3,4,t/;, D9 M) R" ^! _6 i* j2 s
    arcs(nodes,nodes):c,f;
    ! Q2 K/ V! D! I/ P' [endsets
    $ f3 U1 F3 D2 a, c' A: Tdata:
    8 X5 Q8 Q" _, W1 d0 L9 L. z- I5 fc=0;5 M5 A! d5 P  v% v2 N
    @text('fdata.txt')=f;
    7 w- \8 Y7 P8 f+ Y, Oenddata! V, \  w/ l2 s3 r6 Q% b
    calc:9 z+ ~# @7 _! O; N: \
    c(1,2)=8;c(1,4)=7;
    % L. ~8 ]. v6 D3 S* i% P/ l: `c(2,3)=9;c(2,4)=5;, \0 N. ^3 n5 y8 \8 v9 [
    c(3,4)=2;c(3,6)=5;) N4 I* h6 A2 t! o! J/ \
    c(4,5)=9;c(5,3)=6;c(5,6)=10;" a, R2 i. @9 ?) Y% ?6 P% Q3 N
    endcalc
    ( ~: c+ H5 n. N9 e0 n7 qn=@size(nodes); !顶点的个数;
    # P5 }( E0 d. M; T6 U7 t/ C! c- H7 [max=flow;; X$ X2 n8 p) m3 o- D/ j
    @for(nodes(i)|i #ne#1 #and# i #ne# n:( i- M  M7 u- D6 H
        @sum(nodes(j):f(i,j))=@sum(nodes(j):f(j,i)));" _; P0 N0 r9 y& I' t- t7 ]& w
    @sum(nodes(i):f(1,i))=flow;
    ( K2 N. w. Q  _$ \9 {, w@sum(nodes(i):f(i,n))=flow;
    7 W/ g& f2 _4 w& T$ N. f6 L" J@for(arcsbnd(0,f,c));
    7 K: D+ @! v" O4 Iend0 ?. B4 _" h9 N  Y  }% s5 N

    . |9 T5 P) W: ]7 N3 _; Z) G# n5 y————————————————! ^0 P' ?% u7 Q
    版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。% n, j6 ?5 ]7 g' K4 K# J
    原文链接:https://blog.csdn.net/qq_29831163/article/details/897863137 t% H+ P" R1 h1 K5 k+ b
    ' ~0 w; T' i8 |4 R1 G7 B) H/ E

    4 [# ]1 |+ _8 F6 K
    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 18:46 , Processed in 0.430865 second(s), 51 queries .

    回顶部