QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1946|回复: 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 d5 J$ G0 e$ j* k6 l
    1.1 网络中的流 定义% {/ d5 _5 T" v# M
    在以V 为节点集, A 为弧集的有向图G = (V, A) 上定义如下的权函数:3 F( W4 g8 v3 u. M. }$ z
    % @- C8 m/ G# ?6 k  S8 I. q: e
    (i) L : A → R 为孤上的权函数,弧 (i, j)∈ A 对应的权 L(i, j) 记为 ,称为孤 (i, j) 的容量下界(lower bound);4 g+ n' f' E" H

    , L  N4 W+ {$ C5 n(ii)U : A → R 为弧上的权函数,弧(i, j)∈ A对应的权U(i, j) 记为 ,称为孤 (i, j) 的容量上界或容量(capacity);6 z6 U3 ^$ W: E+ o+ ?

    ) x6 v  }$ a0 c( _5 ](iii) D :V → R 为顶点上的权函数,节点i ∈V 对应的权 D(i) 记为  ,称为顶 点i 的供需量(supply/demand);
    ) y% s. v5 Z5 c# @8 \
    1 L, J  C) x0 n此时所构成的网络称为流网络,可以记为 N = (V, A, L,U,D) 。 由于我们只讨论V, A 为有限集合的情况,所以对于弧上的权函数 L,U 和顶点上的 权函数 D ,可以直接用所有孤上对应的权和顶点上的权组成的有限维向量表示,因此 L,U, D 有时直接称为权向量,或简称权。由于给定有向图G = (V, A) 后,我们总是可 以在它的弧集合和顶点集合上定义各种权函数,所以流网络一般也直接简称为网络。9 W7 L% b" N; [$ `+ w( y: M

    ' X3 }$ T! \0 q; `  a在流网络中,弧(i, j) 的容量下界  和容量上界表示的物理意义分别是:通过该 弧发送某种“物质”时,必须发送的最小数量为 ,而发送的最大数量为 。顶点i ∈V 对应的供需量则表示该顶点从网络外部获得的“物质”数量( > 0时),或从该顶 点发送到网络外部的“物质”数量(< 0 时)。下面我们给出严格定义。/ E" K5 U+ K4 Q, G7 n

    ; C& J9 o5 H$ o0 Y可行流(feasible flow)$ W& r7 {" u- v

    4 w: Y" U; D) @8 h
    * F/ `' _% }" r2 D! f6 m" Z' C7 O( Q6 b$ M5 W8 e' r) R
    . t5 Q$ j! @1 p7 T2 S% [0 ?
    可见,当 di > 0时,表示有di 个单位的流量从网络外部流入该顶点,因此顶点i 称 为供应点(supply node)或源(source),有时也形象地称为起始点或发点等;当di < 0 时,表示有|di | 个单位的流量从该顶点流失到网络外部(或说被该顶点吸收),因此顶 点i 称为需求点(demand node)或汇(sink),有时也形象地称为终止点或收点等;当 di = 0时,顶点i 称为转运点(transshipment node)或平衡点、中间点等。此外,根据 (1)可知,对于可行网络,必有
    ! o4 F/ a- `# [& t$ ]7 i- ^0 a9 G
    5 f+ z9 g$ R, R2 I& J$ [, U$ d. R% O2 \  T

    ) V. @# Z. d6 |, p8 D; y4 m也就是说,所有节点上的供需量之和为 0 是网络中存在可行流的必要条件
    3 @: }! E1 Q! s, G1 E! {
    * W: S: c% @' b* A' `2 l" Z" _, g+ O

    : o9 L! N# M5 M) H& s5 X0 m. F5 n8 v; x9 P& F
    1.2 最大流问题
      y& ]1 I0 s$ K/ C3 f考虑如下流网络 N = (V, A,U,D):节点 s 为网络中唯一的源点,t 为唯一的汇点, 而其它节点为转运点。如果网络中存在可行流 f ,此时称流 f 的流量(或流值,flow value)为 (根据(3),它自然也等于 −  ),通常记为v 或v( f ) ,即8 ]6 K+ F) V5 _. S6 ^
    1 C- W! O5 u0 p* j% }) N* V+ }1 R
    - k& w9 o0 \6 `6 k
    对这种单源单汇的网络,如果我们并不给定  和  (即流量不给定),则网络一 般记为 N = (s,t,V, A,U) 。最大流问题( maximum flow problem )就是在 N = (s,t,V, A,U) 中找到流值最大的可行流(即最大流)。我们将会看到,最大流问题 的许多算法也可以用来求解流量给定的网络中的可行流。也就是说,当我们解决了最大 流问题以后,对于在流量给定的网络中寻找可行流的问题,通常也就可以解决了。
    ( M9 \5 J5 v  f- |* X% S  H' ?+ B- b7 ~$ s* u
    用线性规划描述最大流问题
    5 F2 G+ F. v5 G8 O1 R& I- N因此,用线性规划的方法,最大流问题可以形式地描述如下:+ u* [" G" p& e% D

    / h4 ^3 R5 _) J! Y4 m7 `& H4 ?- i  D

    , A6 s" Y+ _! L! [2 {定义】 如果一个矩阵 A 的任何子方阵的行列式的值都等于0,1或 −1,则称 A 是 全幺模的(totally unimodular TU,又译为全单位模的),或称 A 是全幺模矩阵。
    2 {6 [# z2 l. I* t% O" v8 W# z' Z& n, m" K3 h* }" y
    整流定理
    . i& i% H7 V# B/ n0 ^' }; s【定理 7】(整流定理) 最大流问题所对应的约束矩阵是全幺模矩阵。若所有弧容量 均为正整数,则问题的最优解为整数解。 最大流问题是一个特殊的线性规划问题。我们将会看到利用图的特点,解决这个问 题的方法较之线性规划的一般方法要方便、直观得多。
    8 R) r; M& r1 q/ T7 n4 F) _4 N8 }" J! e$ Z
    1.3 单源和单汇运输网络
    . u" m. \. n0 P5 @7 H多源多汇网络 转化成单源单汇网络9 S/ F$ C6 T- ]8 N7 s
    实际问题往往是多源多汇网络,为了计算的规格化,可将多源多汇网络G 化成单 源单汇网络G' 。设 X 是G 的源,Y 是G 的汇,具体转化方法如下:3 F2 V, T. x. U: _) S$ }: }/ M
    9 V6 A3 o. F% B8 l- d) P
    (i)在原图G 中增加两个新的顶点 x 和 y ,令为新图G' 中之单源和单汇,则G 中 所有顶点V 成为G' 之中间顶点集。, i0 G9 r7 K! r
    3 d- u- I9 y4 s! R
    (ii)用一条容量为∞的弧把 x 连接到 X 中的每个顶点。
    5 w/ T9 T- k: c# i9 v. E* w, q7 s( D
    (iii)用一条容量为∞的弧把Y 中的每个顶点连接到 y 。 G 和G' 中的流以一个简单的方式相互对应。若 f 是G 中的流,则由
    2 X, _, m4 s# J5 _  }9 \0 y* e
    7 ~4 r! R9 _7 @4 I$ f$ D2 E) i: y7 B
    , u  a" ~- R; m& n& w
    2 最大流和最小割关系割的容量' |. X1 q" m3 Y: Y7 j% ]7 O
    , c. L) M, K9 M. O( z, q/ {  z
    . B4 _& t+ A0 r6 w

    ' h! G% v  _$ e' w6 t/ @- M( H则在这条可增广轨上每条前向弧的流都可以增加一个量δ ,而相应的后向弧的流可减 少δ ,这样就可使得网络的流量获得增加,同时可以使每条弧的流量不超过它的容量, 而且保持为正,也不影响其它弧的流量。总之,网络中 f 可增广轨的存在是有意义的, 因为这意味着 f 不是最大流。! Z" z7 l$ q; K5 R2 Q# E. X
    % e, f1 K) P5 }2 y  b4 a' M
    3 最大流的一种算法—标号法  L! @7 J$ M$ B. O* ]
    标号法是由 Ford 和 Fulkerson 在 1957 年提出的。用标号法寻求网络中最大流的基 本思想是寻找可增广轨,使网络的流量得到增加,直到最大为止。即首先给出一个初始 流,这样的流是存在的,例如零流。如果存在关于它的可增广轨,那么调整该轨上每条 弧上的流量,就可以得到新的流。对于新的流,如果仍存在可增广轨,则用同样的方法 使流的值增大,继续这个过程,直到网络中不存在关于新得到流的可增广轨为止,则该 流就是所求的最大流。4 n  z. i5 B2 G- S7 h6 u9 w- M
    % d7 U+ q; `$ s+ j( u  i3 h+ ?
    这种方法分为以下两个过程:
    5 q) {- t+ p8 ~( ^/ U8 u, u
    3 t: _9 X9 k3 b" i" e5 mA.标号过程:通过标号过程寻找一条可增广轨。
    & {3 E' g0 y: a- ^; u$ f0 b
    : x# V! Z! ~5 ?) J2 a4 z6 rB.增流过程:沿着可增广轨增加网络的流量。
    7 w0 q7 k. z8 b# @6 u
    ( B/ r  ^4 e* R* w& ^: ~* L0 n4 m这两个过程的步骤分述如下。
      g6 i, K# G6 i" V$ Y7 o7 V7 n3 E. g+ H5 U
    (A)标号过程:$ Y/ N$ |; }6 r; g

    # o# i  r' s+ h, S. D0 e% C; z6 l5 k% k/ T4 t/ Z; d% g2 g9 \1 i

    9 e( K2 [0 Q6 j  {3 l) O(B)增流过程
    0 d# Y3 e5 T" @+ R" I  }& a  s3 R1 T- |
    网络最大流 x 的求解步骤
    9 `& f9 w1 g  e) j3 z求网络 N = (s,t,V, A,U) 中的最大流 x 的算法的程序设计具体步骤如下:
    $ f2 \, E; {% ^7 z* W2 y  k8 z3 q( n, c7 \& K8 h3 z* F6 q$ x
    对每个节点 j ,其标号包括两部分信息 (pred( j),maxf(j))& ]& O$ a* C$ J. V# ~! o
    3 S& O  C2 X) S+ S( R! ^
    该节点在可能的增广路中的前一个节点 pred( j) ,以及沿该可能的增广路到该节点为止 可以增广的最大流量 maxf( j)。4 w0 O/ \' J5 J& F

    ( K  k* \4 d: f* w. Y" S: C3 M+ a) s

    5 D: k. A5 f9 H' P( x, G0 ~% {6 w8 q

    并将 j 加入 LIST 中。

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

    - s% Q+ `9 ?& j4 c

    % S* P8 b# M! K  e* \7 s: W
    4 d  o: H9 P5 p- }9 E' k4 X' A6 ~2 \  D解 编写程序如下:$ l" V: n. p2 h3 b9 V$ }  [" @

    " V2 _' _1 M- z+ [clc,clear
    - a: L- Y  A$ ^, Q; u+ ru(1,2)=1;u(1,3)=1;u(1,4)=2;u(2,3)=1;u(2,5)=2;
    9 `3 I0 `+ ^6 t8 \u(3,5)=1;u(4,3)=3;u(4,5)=3;4 U# m9 Z, N/ k# s" D( x* r
    f(1,2)=1;f(1,3)=0;f(1,4)=1;f(2,3)=0;f(2,5)=1;
    9 R7 f' p6 w( d5 Y7 K3 Y1 ?f(3,5)=1;f(4,3)=1;f(4,5)=0;
    1 q  ^. [+ B3 P3 U% Un=length(u);list=[];maxf(n)=1;1 F% b6 a' S4 H6 O+ F1 c
    while maxf(n)>0
    & O9 Q+ f: Q+ Hmaxf=zeros(1,n);pred=zeros(1,n);
    / A7 O1 Y" M8 |& \" I) T- ^3 olist=1;record=list;maxf(1)=inf;7 U. _6 b! s/ w( w! l
    % list是未检查邻接点的标号点,record是已标号点
    ) n/ J3 M5 Q1 t$ q2 twhile (~isempty(list))&(maxf(n)==0)0 G2 X7 r' b' X7 q
        flag=list(1);list(1)=[];) ^2 m2 S0 J* e: g! q; {1 n9 ~  S
        label1= find(u(flag,-f(flag,);$ [6 y. G, [4 Y7 B+ w0 F, F
        label1=setdiff(label1,record);
    ! G0 [7 F' W/ W; R* A& L    list=union(list,label1);
    ' o- s, g. N$ m" Y9 @( V7 d    pred(label1)=flag;3 K1 h9 u3 R! L
        maxf(label1)=min(maxf(flag),u(flag,label1)...+ z* F4 P9 Z. R' w/ [) L
        -f(flag,label1));8 `. H7 o9 c6 o- ~
        record=union(record,label1);$ `' w2 t8 H& Z8 m% A8 Z2 N, E5 F
        label2=find(f(:,flag));- n+ C$ l% B1 r7 k
        label2=label2';
    : l0 r5 S  U) z- w0 U    label2=setdiff(label2,record);; _. N; U7 U8 g, q* g
        list=union(list,label2);
    ; |+ L! e$ b9 V& o- f; Y    pred(label2)=-flag;9 m3 w* i% N7 \$ A1 k' E
        maxf(label2)=min(maxf(flag),f(label2,flag));( E* Q  Z& C& i
        record=union(record,label2);
    / X1 A; q& E- d/ i9 W; O  t end  |4 X1 X0 U. u' G$ y5 h2 ?
         if maxf(n)>0" V. p  F) p# n) N- M5 u7 s* c+ e7 k
            v2=n; v1=pred(v2);- l2 ~3 ~3 z: D& P4 g( \
            while v2~=19 G2 B6 z; ?" N$ `' k4 z
                if v1>0
    3 R8 V" Q+ t9 A" H: @9 k( d/ C                f(v1,v2)=f(v1,v2)+maxf(n);
      u2 R4 L: h: O( {7 }6 S- H8 v            else
    # n0 P5 H0 O6 Z9 i. M! S                v1=abs(v1);
    0 n/ X! B. D8 y4 Z7 S4 W' \                f(v2,v1)=f(v2,v1)-maxf(n);
    . j: M# h4 u7 u  t( C, T: h            end
    ' f/ z5 r$ Q9 L. s+ \% q3 j) @            v2=v1; v1=pred(v2);1 G$ N$ o/ `) T4 ]8 }9 Z( I
            end
    0 R, M/ A6 [7 l: S6 l4 l    end# u  z4 u5 w* K3 f
    end
    : x, ]7 d" `; j, }/ Af : T; y! R6 E# R& t6 l4 A# ]( Y
    例18 现需要将城市 s 的石油通过管道运送到城市t ,中间有4个中转站  v1 ,v2 ,v3 和  v4 ,城市与中转站的连接以及管道的容量如图7所示,求从城市 s 到城市t 的最大流。
    % b6 {9 q3 W# w6 l1 [/ E) j$ U) P$ ]* P. m2 @! C% J
    9 P# }! R" z8 w+ g* {

    3 A7 o% B4 K( {* Q/ i
    8 M/ z! s+ S0 [. C解 使用最大流的数学规划表达式,编写LINGO程序如下:, \4 d3 ^; m8 V$ K

    ! c$ D8 h4 b3 B; L! r3 S4 Q  Q6 ?! Wmodel:
    % Z4 t( c7 \% |+ f( K) jsets:/ S  @5 d: @1 N$ ^) h1 O
    nodes/s,1,2,3,4,t/;
    & P" \4 m% x, Uarcs(nodes,nodes)/s 1,s 3,1 2,1 3,2 3,2 t,3 4,4 2,4 t/:c,f;% C. g. X+ t  r+ N
    endsets
    5 d. w/ D, g5 e- l$ Xdata:
    : ?! E; K' H: O7 G8 rc=8 7 9 5 2 5 9 6 10;
    6 [" H9 u- l* F! cenddata' `' I0 f6 G4 ^- d
    n=@size(nodes); !顶点的个数;- j) T0 b' w: ^1 h  r4 X- ^% @
    max=flow;
    : p, L2 v: \) j2 S/ m@for(nodes(i)|i #ne#1 #and# i #ne# n:  D$ W  O8 h9 Z2 S
        @sum(arcs(i,j):f(i,j))=@sum(arcs(j,i):f(j,i)
    2 E" ~, n+ m0 ~) }! r: b5 N@sum(arcs(i,j)|i #eq# 1:f(i,j))=flow;- J% u/ A) V- B
    @sum(arcs(i,j)|j #eq# n:f(i,j))=flow;
    ! p/ D2 I" f  x. R# r9 n@for(arcsbnd(0,f,c));
    : Q: B+ S2 |5 W: kend . Z  F% f  j9 T/ q+ G

    % S. A, x9 D& F7 T, k$ @# Z( ~在上面的程序中,采用了稀疏集的编写方法。下面介绍的程序编写方法是利用赋权邻 接矩阵,这样可以不使用稀疏集的编写方法,更便于推广到复杂网络。
    9 n, }/ D1 L" l; w$ S
    & a6 m/ w5 r+ hmodel:" g  I6 S, w* D
    sets:
    % O1 F0 S, n7 D* e" L  Nnodes/s,1,2,3,4,t/;( W! F, a1 b8 m
    arcs(nodes,nodes):c,f;
    * j, T( f, \" A4 Y& @" Y$ iendsets
    ! K' }/ D; ]3 L& v8 x% h9 ]data:' _( G6 W$ `5 c. @" [
    c=0;. \# o6 \( Y% B
    @text('fdata.txt')=f;
    ) ^$ \1 c* s+ d5 \* E% Penddata6 g) ^' I# \% e  v2 Q0 V7 f
    calc:7 l  i* x7 R2 R$ Z1 F
    c(1,2)=8;c(1,4)=7;3 K# ?, L( q& g) Y
    c(2,3)=9;c(2,4)=5;! W3 i2 C3 O* o- ?# h) j
    c(3,4)=2;c(3,6)=5;! j+ _3 T! i1 I/ Z- S: H
    c(4,5)=9;c(5,3)=6;c(5,6)=10;+ K6 `7 z7 |5 ^
    endcalc
    - _- r) Y" b7 P, R. [& In=@size(nodes); !顶点的个数;5 k6 L2 ?# a! C3 F$ e. \
    max=flow;
    ( O' P0 o4 U3 j6 e7 U# k@for(nodes(i)|i #ne#1 #and# i #ne# n:
    ( _$ }& u0 ~5 H1 Y2 V+ E    @sum(nodes(j):f(i,j))=@sum(nodes(j):f(j,i)));
    3 z! M2 f! `' @  F. L@sum(nodes(i):f(1,i))=flow;
    0 m% C2 _- S! u+ V8 f& T@sum(nodes(i):f(i,n))=flow;7 y# q. O1 z7 k$ G4 {1 G
    @for(arcsbnd(0,f,c));
    $ j! X* X6 `- Q6 ?3 D# Dend
    ; Y& s" m! A: N7 R. B" R7 o# L( u7 V. h% N
    ————————————————
    # K  q/ i8 E' X" y3 O  D版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。3 I/ Y% T. D1 c) E3 z! @7 b1 k& a
    原文链接:https://blog.csdn.net/qq_29831163/article/details/89786313+ M4 I/ @% b& [# J2 s, l  k
    9 I7 a6 K/ \" b- x( e

    / @& `+ e4 h6 A' k4 Q# ^
    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:21 , Processed in 0.443261 second(s), 52 queries .

    回顶部