QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1948|回复: 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 最大流问题的数学描述
    / B* v( m( `  v; C% O1.1 网络中的流 定义* k* G, ~5 G0 @! _
    在以V 为节点集, A 为弧集的有向图G = (V, A) 上定义如下的权函数:
    ! M# V" p9 z* O. L6 \3 N, f5 n6 W3 }3 O9 F. q; i/ ]3 G9 D
    (i) L : A → R 为孤上的权函数,弧 (i, j)∈ A 对应的权 L(i, j) 记为 ,称为孤 (i, j) 的容量下界(lower bound);
    $ q9 G0 C9 Q8 c5 I" S
      |6 d: i5 [: d! A. h* q(ii)U : A → R 为弧上的权函数,弧(i, j)∈ A对应的权U(i, j) 记为 ,称为孤 (i, j) 的容量上界或容量(capacity);
    8 l+ ?1 E# [/ v& i$ D
    6 u; O6 |5 }0 U6 Z% Y6 d, G% e6 F( T(iii) D :V → R 为顶点上的权函数,节点i ∈V 对应的权 D(i) 记为  ,称为顶 点i 的供需量(supply/demand);4 f# ?/ G; C) L" d+ p7 u. g

    $ `. `$ ], n  h; n此时所构成的网络称为流网络,可以记为 N = (V, A, L,U,D) 。 由于我们只讨论V, A 为有限集合的情况,所以对于弧上的权函数 L,U 和顶点上的 权函数 D ,可以直接用所有孤上对应的权和顶点上的权组成的有限维向量表示,因此 L,U, D 有时直接称为权向量,或简称权。由于给定有向图G = (V, A) 后,我们总是可 以在它的弧集合和顶点集合上定义各种权函数,所以流网络一般也直接简称为网络。
    : u) ^$ ]) f: A% G9 V! f  y
    " N, m, f2 x/ L4 y3 ?在流网络中,弧(i, j) 的容量下界  和容量上界表示的物理意义分别是:通过该 弧发送某种“物质”时,必须发送的最小数量为 ,而发送的最大数量为 。顶点i ∈V 对应的供需量则表示该顶点从网络外部获得的“物质”数量( > 0时),或从该顶 点发送到网络外部的“物质”数量(< 0 时)。下面我们给出严格定义。' j! K% j5 [# i: _+ L3 c5 J

    7 l- T) J8 d7 C. H" L可行流(feasible flow)
    ' M/ \) j, o( B% z# C0 x; [" h( a  g9 L- @, I
    / g9 ?6 S* @: E, B0 S! ^
    % R1 a9 B! Y+ d0 D
    + x5 o0 [6 e# a# M# Y. W# _
    可见,当 di > 0时,表示有di 个单位的流量从网络外部流入该顶点,因此顶点i 称 为供应点(supply node)或源(source),有时也形象地称为起始点或发点等;当di < 0 时,表示有|di | 个单位的流量从该顶点流失到网络外部(或说被该顶点吸收),因此顶 点i 称为需求点(demand node)或汇(sink),有时也形象地称为终止点或收点等;当 di = 0时,顶点i 称为转运点(transshipment node)或平衡点、中间点等。此外,根据 (1)可知,对于可行网络,必有
    % ]. j* }; w3 J% X  g0 j  c$ ~- m1 a; P9 V5 {, ]
    ) A% ~5 D4 j, Z8 t) [( _" n
    & j5 b8 U. P6 z5 E' M& _4 U/ C
    也就是说,所有节点上的供需量之和为 0 是网络中存在可行流的必要条件
    $ {, Q  ]0 i* l0 ]' i/ x' ]% A/ I) u: T

    . w, i# Y8 W4 U- d/ K7 @4 J+ e  k
    . v! w9 z! M+ y) W
    $ R. L, j. W, q9 v, ~1.2 最大流问题
    # f& \& J5 M$ y/ ~6 j% p4 F考虑如下流网络 N = (V, A,U,D):节点 s 为网络中唯一的源点,t 为唯一的汇点, 而其它节点为转运点。如果网络中存在可行流 f ,此时称流 f 的流量(或流值,flow value)为 (根据(3),它自然也等于 −  ),通常记为v 或v( f ) ,即7 I9 l& F/ ?5 t' D7 f) I" P7 W  A

    / t0 u9 _! u$ m* N7 {' t7 U; b# _8 r* k
    对这种单源单汇的网络,如果我们并不给定  和  (即流量不给定),则网络一 般记为 N = (s,t,V, A,U) 。最大流问题( maximum flow problem )就是在 N = (s,t,V, A,U) 中找到流值最大的可行流(即最大流)。我们将会看到,最大流问题 的许多算法也可以用来求解流量给定的网络中的可行流。也就是说,当我们解决了最大 流问题以后,对于在流量给定的网络中寻找可行流的问题,通常也就可以解决了。  m. B, j: k  z5 U/ O1 t/ m
    ; M$ Q( ^8 `3 H
    用线性规划描述最大流问题
    2 ?# n5 s# i; m3 \因此,用线性规划的方法,最大流问题可以形式地描述如下:/ B# v7 ?" L. m

    / S: l: B: k' Z' U9 |9 E' J2 b/ e7 a1 w3 X  G& m+ C5 a% g

    3 T5 o) m# T: Z+ }: v) S, d1 c定义】 如果一个矩阵 A 的任何子方阵的行列式的值都等于0,1或 −1,则称 A 是 全幺模的(totally unimodular TU,又译为全单位模的),或称 A 是全幺模矩阵。
    : L6 X( a1 l, E
    + |2 N- l( n4 z: K9 y$ |) y" l整流定理* Z% L4 `5 ~0 C9 S3 q: O
    【定理 7】(整流定理) 最大流问题所对应的约束矩阵是全幺模矩阵。若所有弧容量 均为正整数,则问题的最优解为整数解。 最大流问题是一个特殊的线性规划问题。我们将会看到利用图的特点,解决这个问 题的方法较之线性规划的一般方法要方便、直观得多。
    5 W! p3 _1 Z( l. D& @% a3 d0 x! K4 }3 N0 C# W5 H
    1.3 单源和单汇运输网络( a' N$ E$ u" ]' k. `. {+ w0 u
    多源多汇网络 转化成单源单汇网络
    % ]( `9 `$ z7 R) u; r- w实际问题往往是多源多汇网络,为了计算的规格化,可将多源多汇网络G 化成单 源单汇网络G' 。设 X 是G 的源,Y 是G 的汇,具体转化方法如下:
    % n3 O' k& v: r% P5 f" z0 I: t* Y, S8 K- U# I2 o5 B0 q
    (i)在原图G 中增加两个新的顶点 x 和 y ,令为新图G' 中之单源和单汇,则G 中 所有顶点V 成为G' 之中间顶点集。; g2 R  `( t9 D4 @' _2 J+ n

    . U! t! l/ _* D7 p. T(ii)用一条容量为∞的弧把 x 连接到 X 中的每个顶点。' |/ e; L$ {# ^

    4 X8 _' T( A9 T; b6 u( k" y9 [0 C- ^(iii)用一条容量为∞的弧把Y 中的每个顶点连接到 y 。 G 和G' 中的流以一个简单的方式相互对应。若 f 是G 中的流,则由8 K3 ^  ]7 H3 j6 k; _
    + _7 F) B: }( j* k) P8 q
    - k/ l7 C7 _# w, ]2 T

    6 D& e1 {3 a  }0 p; }; }' O/ a& W0 N2 最大流和最小割关系割的容量% q+ r8 V! W; [( b. }# u9 d3 k
    9 z4 G* N9 A% F4 W
    ; G3 ^0 j1 N1 Y! d+ A4 i

    5 \$ f+ J" m6 ~$ q) s" [" @" t则在这条可增广轨上每条前向弧的流都可以增加一个量δ ,而相应的后向弧的流可减 少δ ,这样就可使得网络的流量获得增加,同时可以使每条弧的流量不超过它的容量, 而且保持为正,也不影响其它弧的流量。总之,网络中 f 可增广轨的存在是有意义的, 因为这意味着 f 不是最大流。# I: f7 g% y/ N3 E

    4 A- J' N. [5 R6 n3 最大流的一种算法—标号法
    5 k3 @4 w1 y0 F$ F: M6 Z# S- {标号法是由 Ford 和 Fulkerson 在 1957 年提出的。用标号法寻求网络中最大流的基 本思想是寻找可增广轨,使网络的流量得到增加,直到最大为止。即首先给出一个初始 流,这样的流是存在的,例如零流。如果存在关于它的可增广轨,那么调整该轨上每条 弧上的流量,就可以得到新的流。对于新的流,如果仍存在可增广轨,则用同样的方法 使流的值增大,继续这个过程,直到网络中不存在关于新得到流的可增广轨为止,则该 流就是所求的最大流。
    0 q0 q2 v2 V3 `5 X0 i
    # v: @9 w3 D! [- @( P+ z这种方法分为以下两个过程:' I9 L& w* ]" A! D2 N, Z

    , L& |5 ]! P3 n- L( `% g7 T% qA.标号过程:通过标号过程寻找一条可增广轨。$ ]$ Q$ S; Y9 x, F  r% k

    - l9 y0 y' q3 s" sB.增流过程:沿着可增广轨增加网络的流量。
    % j, r/ E6 X8 P6 [: G/ ~: A7 h0 B& z: l* W" D' M" O1 y
    这两个过程的步骤分述如下。6 P% G' s& ?/ Q, w9 ?/ ]; w2 c6 s* B6 b# N
    9 R3 w5 k" A: k
    (A)标号过程:- p* G; e6 i, x! |+ ]6 k" F

    6 H$ z- `* L0 \0 e6 q" a
    7 h2 n  x+ V" Y5 e1 r+ C! S4 L, K" W: k% G4 {- G" s5 y
    (B)增流过程* x2 R, Z+ |* O8 y5 y) U
    * i* S$ {7 D1 _. r
    网络最大流 x 的求解步骤
    + r' t* p! s# I. b4 P求网络 N = (s,t,V, A,U) 中的最大流 x 的算法的程序设计具体步骤如下:+ w- l0 K. q6 s9 q8 Q

    - d. }; o0 Z+ }6 o( B4 T+ a$ F对每个节点 j ,其标号包括两部分信息 (pred( j),maxf(j)): @0 t! I6 M4 m: s7 q5 p( |" q" m' v! p

      W$ }1 j' t6 A( {该节点在可能的增广路中的前一个节点 pred( j) ,以及沿该可能的增广路到该节点为止 可以增广的最大流量 maxf( j)。' R# E* s' s3 l. ~) y; j* v% i" F
    & \% B$ J- I# w, \3 ~- X
    8 h6 X; ^3 D' e3 u3 G4 {, z: G
    - V3 ^, i+ b- Y8 S% x1 s

    并将 j 加入 LIST 中。

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


    7 c7 F' Q: O! \4 A% {' s# q' u# ]- Q( _. D  K/ b# O0 R

    ' X! k2 w' J. s+ |! E  ]: ]解 编写程序如下:6 t. ^+ j) w! d1 {( |% j$ ~

    / U# j8 x/ R) e- h& @clc,clear; p% T- L8 l( g
    u(1,2)=1;u(1,3)=1;u(1,4)=2;u(2,3)=1;u(2,5)=2;3 w3 p* h/ \4 ]* a+ e) R, p
    u(3,5)=1;u(4,3)=3;u(4,5)=3;  s. n* B9 L. L0 x' T( h
    f(1,2)=1;f(1,3)=0;f(1,4)=1;f(2,3)=0;f(2,5)=1;
    0 y5 o# a# T2 w6 z' ff(3,5)=1;f(4,3)=1;f(4,5)=0;
    ! i3 T) z& {& g+ X" m* I3 Sn=length(u);list=[];maxf(n)=1;
    9 O! X9 u( u% r  O2 V7 kwhile maxf(n)>0: y8 K. {3 N0 |" o7 i9 u
    maxf=zeros(1,n);pred=zeros(1,n);  O2 s" \( I  [5 J* o! Y. W, R
    list=1;record=list;maxf(1)=inf;
    8 W9 V+ g/ r# Z$ ~8 P  T/ @* B) M % list是未检查邻接点的标号点,record是已标号点
    * a8 O, m2 q- M0 x; `& L- ]while (~isempty(list))&(maxf(n)==0)
    : L- n" o- {) t1 j  }6 H  p: D! d    flag=list(1);list(1)=[];
    - j' R; S' a) t& s2 J" y    label1= find(u(flag,-f(flag,);
    ' _. l" ]; X0 z$ m6 B5 t+ a7 p    label1=setdiff(label1,record);
    ) b) [7 H  ?9 s2 g! ?3 n    list=union(list,label1);
      |7 l. Z. L; l7 B. {0 A    pred(label1)=flag;6 k5 l1 n' u9 c; j8 p5 B; S
        maxf(label1)=min(maxf(flag),u(flag,label1)...+ n5 d% g" \7 ~4 P
        -f(flag,label1));, A; i# @+ \$ u8 h
        record=union(record,label1);; f7 w9 ^& c6 ~8 W6 c% e  E; b8 J$ N. M# K
        label2=find(f(:,flag));/ Y' f' b! \* X; g# M
        label2=label2';% S4 N+ ], m% L  _/ x
        label2=setdiff(label2,record);: {8 b8 p3 Q9 ?, w! E# _: t
        list=union(list,label2);* ~3 a  x7 C. x0 Y
        pred(label2)=-flag;6 W5 @: _) W" W
        maxf(label2)=min(maxf(flag),f(label2,flag));' u5 f' f  V  i4 d
        record=union(record,label2);4 b+ Z( f. f1 n
    end2 J/ o# L( h8 p5 J
         if maxf(n)>0
    ) L( {4 I' Q- w4 l$ C4 m        v2=n; v1=pred(v2);
    # P0 @8 U: t8 H+ F# |3 S; X( Y        while v2~=1
    $ L/ C. T! n# @5 I( e            if v1>0
    ' n$ {; M. P  t                f(v1,v2)=f(v1,v2)+maxf(n);
    ( t0 u0 H6 d) ]3 W) A/ x; t            else
    & o1 H% H$ b* a) @7 C                v1=abs(v1);
    ' z: }7 p0 a% n. e: P                f(v2,v1)=f(v2,v1)-maxf(n);2 k; I, T' T2 Z* n# e' ]
                end
    ' L$ \* ~9 F; L8 m6 K            v2=v1; v1=pred(v2);- i: U2 N/ o5 V4 `3 n: I
            end( G$ j( H' [+ N# }
        end# P7 W. j2 O4 {. ~& o
    end  p0 @0 \9 Z3 n
    f . d0 h6 C% a, f6 K# E9 x
    例18 现需要将城市 s 的石油通过管道运送到城市t ,中间有4个中转站  v1 ,v2 ,v3 和  v4 ,城市与中转站的连接以及管道的容量如图7所示,求从城市 s 到城市t 的最大流。) N$ S& q  z( C& s) I

    + z- O( e2 m3 ?% x) Q7 R! E! i8 J1 D: `. p
    : x0 P% d" k* e9 h3 K1 u
    % r* F5 _) A$ R# h: M/ @, }) ]
    解 使用最大流的数学规划表达式,编写LINGO程序如下:# L/ A% D1 m: j7 i. z( i) ?& M
    4 Q+ _/ x1 V* P0 h" W$ S
    model:
    , v0 P. G/ ]9 E5 b5 D& w* [& Esets:
    ! @2 i& Q8 @- `nodes/s,1,2,3,4,t/;
    1 Y: n& P- a% l$ o* E5 J0 ^" F& Narcs(nodes,nodes)/s 1,s 3,1 2,1 3,2 3,2 t,3 4,4 2,4 t/:c,f;& V% @  A* B! W) Y! P
    endsets
    2 G; d: W) W3 ]" g6 ldata:5 l% l: ~, ~) ^1 \' I
    c=8 7 9 5 2 5 9 6 10;& @! N4 o( [: `  ]: u
    enddata+ I& Q! l- }0 s3 V1 n! U
    n=@size(nodes); !顶点的个数;
    2 f3 G2 s7 }3 ]  Qmax=flow;; @% z1 e8 p+ m* N6 z1 g2 f
    @for(nodes(i)|i #ne#1 #and# i #ne# n:' B. l* v2 `1 @1 A
        @sum(arcs(i,j):f(i,j))=@sum(arcs(j,i):f(j,i)! A! b; A% j$ X; B" G4 u% k7 Y
    @sum(arcs(i,j)|i #eq# 1:f(i,j))=flow;
    . J' R) t! F3 Z6 H6 m) w@sum(arcs(i,j)|j #eq# n:f(i,j))=flow;( ]; `# ]3 t" B; {, g
    @for(arcsbnd(0,f,c));- }* c7 c( H' x2 w4 d% T1 r
    end 3 V+ `( U( H8 j3 ~( V" f: d3 C+ q- K

    ' Z! m$ u3 @- d. h- ~在上面的程序中,采用了稀疏集的编写方法。下面介绍的程序编写方法是利用赋权邻 接矩阵,这样可以不使用稀疏集的编写方法,更便于推广到复杂网络。
    2 j6 D7 R+ l7 i9 ?7 [8 r
    0 ~4 k4 ?! u) O+ e  mmodel:, ^' k" x; i( V& S
    sets:% _: ]# t4 y' O9 L! T+ G3 r6 b
    nodes/s,1,2,3,4,t/;3 }  I3 s6 `! M" |) k# p
    arcs(nodes,nodes):c,f;* z# |( z; S9 m0 o* R
    endsets- Y' B- o' Y' Q4 K. {6 s' j
    data:! ^9 H$ y7 }$ t2 c9 Q
    c=0;6 j: E" [" F* v! {  F* `
    @text('fdata.txt')=f;0 k6 }) A! g. F9 y+ z. S
    enddata
    8 d9 f  E% M, t0 K0 T4 ncalc:
    1 E3 k! E# D- ]c(1,2)=8;c(1,4)=7;
    ; G: O4 K/ `7 j4 a. [7 T: ]c(2,3)=9;c(2,4)=5;
    ! s% c5 ^1 l* k6 hc(3,4)=2;c(3,6)=5;
    6 a; [+ k! o" e5 s% Y) `c(4,5)=9;c(5,3)=6;c(5,6)=10;5 Y* g- x: s) n  v
    endcalc* z) U) N7 \+ o) V
    n=@size(nodes); !顶点的个数;
    7 [$ J( u( w3 o3 Hmax=flow;
    : a* J1 S8 z0 N! M: A+ M* C9 @@for(nodes(i)|i #ne#1 #and# i #ne# n:; D+ d; G+ h/ A- Y3 U- I
        @sum(nodes(j):f(i,j))=@sum(nodes(j):f(j,i)));
    2 @7 X0 [2 @, s8 n@sum(nodes(i):f(1,i))=flow;
    ( l. y+ J# d* b9 K. m; S* ?' R@sum(nodes(i):f(i,n))=flow;% b% n, q+ S  w* G
    @for(arcsbnd(0,f,c));0 Q& I; k2 l- T, U" h8 I3 \( M
    end, H* b5 U# w( F. E7 {

    - {2 m8 T/ h7 ~7 J————————————————
    ; w/ `) p- R: k- I8 i& _9 g; i; R; O版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。) v" N) b4 T) J9 v
    原文链接:https://blog.csdn.net/qq_29831163/article/details/89786313/ X5 q3 ^$ l+ F/ T, m4 z

    % [' Y1 {, d3 X4 |* ~( ]+ c3 V$ _6 _1 x) p4 f
    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 05:34 , Processed in 0.574784 second(s), 51 queries .

    回顶部