QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1950|回复: 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 _; m% ~$ Q, S1 t% P1.1 网络中的流 定义
    # f6 e& x+ ]: u* S( ]5 O$ G在以V 为节点集, A 为弧集的有向图G = (V, A) 上定义如下的权函数:* M- _- A" S8 Q7 m

    ' T5 s" @; R9 M; }(i) L : A → R 为孤上的权函数,弧 (i, j)∈ A 对应的权 L(i, j) 记为 ,称为孤 (i, j) 的容量下界(lower bound);+ x* v( `% I3 o
    $ @# }9 p5 Q" a+ r% }
    (ii)U : A → R 为弧上的权函数,弧(i, j)∈ A对应的权U(i, j) 记为 ,称为孤 (i, j) 的容量上界或容量(capacity);2 B/ O0 w, H4 H4 O# h
    ) z/ x! u) |! j" h, u' e- f& }
    (iii) D :V → R 为顶点上的权函数,节点i ∈V 对应的权 D(i) 记为  ,称为顶 点i 的供需量(supply/demand);
    ) V# z2 c9 r* k; t( M' o+ t. y' J: Y& q8 a# c
    此时所构成的网络称为流网络,可以记为 N = (V, A, L,U,D) 。 由于我们只讨论V, A 为有限集合的情况,所以对于弧上的权函数 L,U 和顶点上的 权函数 D ,可以直接用所有孤上对应的权和顶点上的权组成的有限维向量表示,因此 L,U, D 有时直接称为权向量,或简称权。由于给定有向图G = (V, A) 后,我们总是可 以在它的弧集合和顶点集合上定义各种权函数,所以流网络一般也直接简称为网络。
    5 z/ N1 ^) [9 e, l, Y- Y+ [& y2 Y' J# P1 s# B8 u! T
    在流网络中,弧(i, j) 的容量下界  和容量上界表示的物理意义分别是:通过该 弧发送某种“物质”时,必须发送的最小数量为 ,而发送的最大数量为 。顶点i ∈V 对应的供需量则表示该顶点从网络外部获得的“物质”数量( > 0时),或从该顶 点发送到网络外部的“物质”数量(< 0 时)。下面我们给出严格定义。- ]& r4 A. @5 k8 W# V" _* D

    ; D. `& a; o: a# b2 ~3 y可行流(feasible flow)( |% K1 n: e( a8 F0 T9 F, l  i
    6 l7 W: m0 j. F, z

    & o- n2 r: n" x) q& A7 j0 g! q# @8 S; W$ O) H

    / \  h: f7 J7 q. E" `3 o可见,当 di > 0时,表示有di 个单位的流量从网络外部流入该顶点,因此顶点i 称 为供应点(supply node)或源(source),有时也形象地称为起始点或发点等;当di < 0 时,表示有|di | 个单位的流量从该顶点流失到网络外部(或说被该顶点吸收),因此顶 点i 称为需求点(demand node)或汇(sink),有时也形象地称为终止点或收点等;当 di = 0时,顶点i 称为转运点(transshipment node)或平衡点、中间点等。此外,根据 (1)可知,对于可行网络,必有2 m. q6 |) g/ s9 B6 ?7 M3 t% l- R
    / z- x: _3 f" a

      W. }% z$ k' a6 z% B0 C. W' _1 X" V4 H& \8 e! {
    也就是说,所有节点上的供需量之和为 0 是网络中存在可行流的必要条件
    - b, c. w( q# A. d' ~* }7 D1 ~
    4 l0 s, I1 g3 o% s( \0 n* f
    ! s$ U" _' j4 k) ?
    6 V5 \* F. }) ?" v& N7 v
    ; T* v* R% Y! v, P1 k" T% F1.2 最大流问题
    6 g& L; ?6 J) @0 f考虑如下流网络 N = (V, A,U,D):节点 s 为网络中唯一的源点,t 为唯一的汇点, 而其它节点为转运点。如果网络中存在可行流 f ,此时称流 f 的流量(或流值,flow value)为 (根据(3),它自然也等于 −  ),通常记为v 或v( f ) ,即
    ( \2 G& n& }7 B0 w! X+ m4 P  p5 v% h, W7 m1 A  R* P
    % I/ L  s5 A5 r2 u
    对这种单源单汇的网络,如果我们并不给定  和  (即流量不给定),则网络一 般记为 N = (s,t,V, A,U) 。最大流问题( maximum flow problem )就是在 N = (s,t,V, A,U) 中找到流值最大的可行流(即最大流)。我们将会看到,最大流问题 的许多算法也可以用来求解流量给定的网络中的可行流。也就是说,当我们解决了最大 流问题以后,对于在流量给定的网络中寻找可行流的问题,通常也就可以解决了。
    % E, \, \5 ]8 b
    2 j1 S7 L/ E. e0 D3 ~; c用线性规划描述最大流问题
    " {% g# `$ T: b因此,用线性规划的方法,最大流问题可以形式地描述如下:
    ' A( k4 `+ b5 {- z. _
    ' T  n0 o, ]7 }: f. v% s
    / G$ c6 b) Z/ l/ O. f
    2 ^* M! x7 e* }0 m+ \6 ~4 {定义】 如果一个矩阵 A 的任何子方阵的行列式的值都等于0,1或 −1,则称 A 是 全幺模的(totally unimodular TU,又译为全单位模的),或称 A 是全幺模矩阵。& H# K; n% t: l

    2 P- `$ z' K2 g0 ~$ O整流定理
      s" ^, E4 ~( f. N【定理 7】(整流定理) 最大流问题所对应的约束矩阵是全幺模矩阵。若所有弧容量 均为正整数,则问题的最优解为整数解。 最大流问题是一个特殊的线性规划问题。我们将会看到利用图的特点,解决这个问 题的方法较之线性规划的一般方法要方便、直观得多。4 G3 i" `' U% E
    * X. |7 H' p4 I1 D0 G4 @
    1.3 单源和单汇运输网络* b5 W- f7 G3 P
    多源多汇网络 转化成单源单汇网络
    * @7 V6 H6 ~3 z9 c$ V+ g1 G实际问题往往是多源多汇网络,为了计算的规格化,可将多源多汇网络G 化成单 源单汇网络G' 。设 X 是G 的源,Y 是G 的汇,具体转化方法如下:" G7 ], Z9 F* J5 y( F# ~6 M

    $ V4 S( N3 t$ q4 u(i)在原图G 中增加两个新的顶点 x 和 y ,令为新图G' 中之单源和单汇,则G 中 所有顶点V 成为G' 之中间顶点集。! l5 \; Q, }* X1 X. l- q9 E

    # ^/ i! N8 y5 D& X! d(ii)用一条容量为∞的弧把 x 连接到 X 中的每个顶点。4 S) z: k0 u' ~' f; D0 L& k

    / _4 H1 g3 q. p(iii)用一条容量为∞的弧把Y 中的每个顶点连接到 y 。 G 和G' 中的流以一个简单的方式相互对应。若 f 是G 中的流,则由
    5 P2 S4 ^: O, D; w5 k! l
    6 g1 O4 Y/ h8 X
    * k1 G; v0 r" R! o0 z+ O0 q
    9 S; B2 d! e% m/ C4 x9 v2 最大流和最小割关系割的容量
    / n! h/ Q9 g  Q0 \+ D; z% Y, P; ~# ?9 v$ g1 ^6 X. c

    1 Y* J: f' B1 E( i5 z
    4 \! c# X) j* c# r则在这条可增广轨上每条前向弧的流都可以增加一个量δ ,而相应的后向弧的流可减 少δ ,这样就可使得网络的流量获得增加,同时可以使每条弧的流量不超过它的容量, 而且保持为正,也不影响其它弧的流量。总之,网络中 f 可增广轨的存在是有意义的, 因为这意味着 f 不是最大流。# g6 d3 l; U, ^: `# k

      d( |7 u' r% p* r& L& |3 最大流的一种算法—标号法
    5 J/ G% v) t3 t# V! m5 L  g标号法是由 Ford 和 Fulkerson 在 1957 年提出的。用标号法寻求网络中最大流的基 本思想是寻找可增广轨,使网络的流量得到增加,直到最大为止。即首先给出一个初始 流,这样的流是存在的,例如零流。如果存在关于它的可增广轨,那么调整该轨上每条 弧上的流量,就可以得到新的流。对于新的流,如果仍存在可增广轨,则用同样的方法 使流的值增大,继续这个过程,直到网络中不存在关于新得到流的可增广轨为止,则该 流就是所求的最大流。5 X$ U$ f& k. @  i
      V. ?# V5 K) J+ E9 [
    这种方法分为以下两个过程:
    # G; V( e1 q  X9 e7 u4 I8 U* K9 J. \8 }5 W& ]
    A.标号过程:通过标号过程寻找一条可增广轨。
    : d: H7 s% ^% {" l9 r. S- p9 e  t% v
    B.增流过程:沿着可增广轨增加网络的流量。
    - z9 R) ]( Q* A3 N# n0 O
    $ e! k; h8 C9 Z9 G- X( _& {这两个过程的步骤分述如下。
    0 i& s1 `# l" S. A7 V& B7 b. h2 I3 m2 J
    (A)标号过程:% A. e4 C# w! Z' u* f; x* I

    0 X  O8 R; _. Y9 _$ q2 {. [/ g+ ]2 |. E, X4 E6 |

    % r9 Z% ^8 ~! J9 ?4 [(B)增流过程0 ]( p4 m, Z/ c

    7 w3 t+ e  L: X. x3 p# V  R网络最大流 x 的求解步骤
    0 F8 k' }7 t: j: w5 t求网络 N = (s,t,V, A,U) 中的最大流 x 的算法的程序设计具体步骤如下:, |0 ]4 m# J5 [7 l. H: B: ]' t
    ; E$ h8 K# Z, \5 Y- t
    对每个节点 j ,其标号包括两部分信息 (pred( j),maxf(j)); ]# C! V! e( I& j. j" w5 T& f8 Y
    * N0 F! u# w; K; p9 }* l9 u' E
    该节点在可能的增广路中的前一个节点 pred( j) ,以及沿该可能的增广路到该节点为止 可以增广的最大流量 maxf( j)。& r4 L' e+ j; s

    8 J7 M$ G' \! i; [: I  r3 f# I# B) X
    + O0 v" F$ F* T( I' t) C3 c5 _& {

    并将 j 加入 LIST 中。

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

    ' H4 m8 ?/ l+ p7 v. c* b( C: f. C
    ) |: J+ D# P' |/ b

    * s* g1 N3 U! z3 H# h解 编写程序如下:
    . E1 I1 b$ c' N1 k! Q( m8 I8 Q( h) Q7 m3 K
    clc,clear. g, R) n# s" U0 g$ [3 a
    u(1,2)=1;u(1,3)=1;u(1,4)=2;u(2,3)=1;u(2,5)=2;3 S. |) I7 `# q7 a* x% ?6 N) O
    u(3,5)=1;u(4,3)=3;u(4,5)=3;
    ; E% h9 ]+ D  g( Nf(1,2)=1;f(1,3)=0;f(1,4)=1;f(2,3)=0;f(2,5)=1;- @+ R3 O: x  _$ w$ \7 N
    f(3,5)=1;f(4,3)=1;f(4,5)=0;
    . K: a% @' o7 un=length(u);list=[];maxf(n)=1;, k# y4 }/ m6 [- M5 k
    while maxf(n)>0
    # i7 z. X; r; S. p3 a' Wmaxf=zeros(1,n);pred=zeros(1,n);0 i* _: @' V' N2 _* ?% W+ q: E1 o' o
    list=1;record=list;maxf(1)=inf;5 F4 I# d# ~0 K: V- k
    % list是未检查邻接点的标号点,record是已标号点
    . a6 r* Z3 o' bwhile (~isempty(list))&(maxf(n)==0)
    5 `& p9 N& q, ?2 Z; m+ a: B6 T" x    flag=list(1);list(1)=[];0 e. H9 I* p, g4 G# F
        label1= find(u(flag,-f(flag,);+ o! h/ }$ ^) @# W: A
        label1=setdiff(label1,record);& Y" g6 q& \( T( d4 z  T7 z/ y- Y9 i
        list=union(list,label1);8 y- y9 j7 s3 c" o- Q
        pred(label1)=flag;
    # ], j3 f! c# }: l    maxf(label1)=min(maxf(flag),u(flag,label1)...  o7 _# L2 H8 f! c  q0 n0 J
        -f(flag,label1));) A2 }' x4 O! s% L4 s$ h
        record=union(record,label1);
    ) v- B+ W  d' i  D: X5 J    label2=find(f(:,flag));
    . |4 s5 {9 D' B' z, G5 w" J9 }    label2=label2';
    7 ?8 g. v+ n/ _9 f8 X& B4 ]' ]    label2=setdiff(label2,record);6 T5 t$ G' ~* Q* Y
        list=union(list,label2);8 C) e. x- _( {0 E9 [
        pred(label2)=-flag;
    2 k$ `& u, K+ f. U  a& m! u7 F0 @    maxf(label2)=min(maxf(flag),f(label2,flag));, k6 S6 p0 u, g; R5 l' n2 ]
        record=union(record,label2);
    * M, P! j% F: h8 M: C2 m+ ] end
    6 K: g. @, @3 x: l: r" b+ B8 D# H     if maxf(n)>0
    % g! \/ q- P  S' ]' D( p; G* {        v2=n; v1=pred(v2);
    ) \/ q5 ^! I( M: s' O+ C        while v2~=1. E: c+ \& ]. u
                if v1>04 |6 e! ^5 v- e) X6 P
                    f(v1,v2)=f(v1,v2)+maxf(n);
    4 j) g4 z# I' Y  V9 K# J            else; P! V6 a, L% L
                    v1=abs(v1);
    2 L8 E& w# S% s  t; ^& ^% q                f(v2,v1)=f(v2,v1)-maxf(n);
    & x  d3 P7 T1 X' h( q) a            end9 I0 \9 |; [6 ]/ f
                v2=v1; v1=pred(v2);
    2 t$ L7 e0 q0 h; |9 P  d        end( L* Z( r6 T+ g2 |1 b( v
        end
    1 L$ L, ~8 j9 B* _8 N% Z! zend0 K1 P3 k$ {( L; q! ~: z7 h4 Q4 x+ i
    f 0 ~4 B8 n* r9 F9 O
    例18 现需要将城市 s 的石油通过管道运送到城市t ,中间有4个中转站  v1 ,v2 ,v3 和  v4 ,城市与中转站的连接以及管道的容量如图7所示,求从城市 s 到城市t 的最大流。* ~. U: e  W! R9 F1 c+ B* a7 l

    & R! ^% e. i: u
    4 c9 O* I3 b: D3 F- c# @4 W' H
    5 F2 _1 V/ X6 o0 p9 A5 p% {/ _6 V$ |$ E4 Z: B; I- A( e+ f
    解 使用最大流的数学规划表达式,编写LINGO程序如下:) v5 `+ J4 A- c% V

      j# d: H  d) z' |2 ]3 s% rmodel:7 X5 V2 x) R3 }+ n, L
    sets:
    0 {* D0 q( E( x6 Z: M( {nodes/s,1,2,3,4,t/;: G8 J8 ~5 S& Q1 X) [0 B/ k
    arcs(nodes,nodes)/s 1,s 3,1 2,1 3,2 3,2 t,3 4,4 2,4 t/:c,f;
    + c$ K  l  T, X& w/ }: Xendsets3 `& y  w2 O6 A) X  u4 ^$ C
    data:
    : B. G% ?, T  Y* l7 v7 a* y/ k$ tc=8 7 9 5 2 5 9 6 10;9 K6 |% ]" g3 {
    enddata0 q" ^% }% T2 x- b/ ]. l" S
    n=@size(nodes); !顶点的个数;3 c8 F. T% B- A
    max=flow;( c) \: b' i. v
    @for(nodes(i)|i #ne#1 #and# i #ne# n:/ l* A0 a/ u" d. B
        @sum(arcs(i,j):f(i,j))=@sum(arcs(j,i):f(j,i)
    5 E2 ^( w& P, C/ x@sum(arcs(i,j)|i #eq# 1:f(i,j))=flow;
    . k9 u. Z7 E! a$ e! f4 w7 U@sum(arcs(i,j)|j #eq# n:f(i,j))=flow;8 U; m$ D  y4 g. v2 Y2 y
    @for(arcsbnd(0,f,c));
    / x0 q. X2 w2 |% E( G0 C5 b" Eend $ k3 P3 {0 e# p$ @

    ( m  F5 |+ c. P& E' Y) e0 z3 I在上面的程序中,采用了稀疏集的编写方法。下面介绍的程序编写方法是利用赋权邻 接矩阵,这样可以不使用稀疏集的编写方法,更便于推广到复杂网络。
    7 }8 x" f$ I- B  Q7 l3 U5 Q' k0 W$ D' m. z6 M2 R( g
    model:' U0 `- C9 D3 N2 E. Q1 j( z" O
    sets:
    2 l# o1 k5 i* l, F9 b5 \nodes/s,1,2,3,4,t/;1 y6 G) b& w: g1 n6 u" ^$ c- Q! @; |
    arcs(nodes,nodes):c,f;
    * V( F$ Y: G# I9 R8 J" C8 pendsets. A8 U1 l5 O" ?8 H7 t
    data:
    ; _, Z- u6 L8 N2 bc=0;  F" x! ]! T* R1 U4 }
    @text('fdata.txt')=f;+ C7 b* |4 Y. k5 S9 `
    enddata
    & z2 t3 U( q6 H0 Tcalc:; U0 x" z) Y1 \: h# @
    c(1,2)=8;c(1,4)=7;
    7 ~6 P* p% D6 n: J- b; ec(2,3)=9;c(2,4)=5;
    ; n% a, |$ H. Jc(3,4)=2;c(3,6)=5;7 A& m5 \& ~6 p' F# O. N- V, s
    c(4,5)=9;c(5,3)=6;c(5,6)=10;
    ' t0 T1 E8 e' r8 ?$ Dendcalc
    + h4 d1 R* a0 T+ Nn=@size(nodes); !顶点的个数;
    ! D) u( Q9 B3 y# m6 W. w/ Hmax=flow;
    6 ]" z' y6 _0 `" H7 C% j$ f* l. E# b3 I@for(nodes(i)|i #ne#1 #and# i #ne# n:% w) O, x2 a0 u0 U
        @sum(nodes(j):f(i,j))=@sum(nodes(j):f(j,i)));  P; ^, _; c* v7 ^$ m2 o- d4 W9 t
    @sum(nodes(i):f(1,i))=flow;- ]- J$ n8 j  Q+ m, K/ Z* K
    @sum(nodes(i):f(i,n))=flow;0 y$ k0 i3 D1 F1 \
    @for(arcsbnd(0,f,c));
    + U% i, m. p0 G- Vend% i( L; A6 L) [* ~; ?1 W* p

    9 U" j8 ?6 D- F————————————————$ C  R0 E5 _* P
    版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    * P0 @! C) ^8 V- T0 ^1 G原文链接:https://blog.csdn.net/qq_29831163/article/details/89786313
    : h4 a! T/ |% j) U
    $ a% h9 W- ?4 b- ^2 r: r+ W$ U4 }  j8 t) 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-4-21 20:26 , Processed in 0.318052 second(s), 52 queries .

    回顶部