QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1967|回复: 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 最大流问题的数学描述
    ! D* E: D& w/ N+ ?$ I% |1.1 网络中的流 定义2 w) X, u2 I- Z# v" i  X7 B
    在以V 为节点集, A 为弧集的有向图G = (V, A) 上定义如下的权函数:
    9 S, o1 a  I- r
    / ^) w7 C4 ]6 |7 d3 v( y1 e(i) L : A → R 为孤上的权函数,弧 (i, j)∈ A 对应的权 L(i, j) 记为 ,称为孤 (i, j) 的容量下界(lower bound);* _: G% t4 l9 _) w- J

    ' P5 }7 J1 O0 V! x$ [+ J- @4 F(ii)U : A → R 为弧上的权函数,弧(i, j)∈ A对应的权U(i, j) 记为 ,称为孤 (i, j) 的容量上界或容量(capacity);4 N+ [/ F" Z- h3 ^. _

    # @  o1 ~2 H( ]  |# C+ L( G(iii) D :V → R 为顶点上的权函数,节点i ∈V 对应的权 D(i) 记为  ,称为顶 点i 的供需量(supply/demand);  h# N6 Q9 ^( ^4 P' A% D

    2 O- |3 W; h3 C! q, E* l此时所构成的网络称为流网络,可以记为 N = (V, A, L,U,D) 。 由于我们只讨论V, A 为有限集合的情况,所以对于弧上的权函数 L,U 和顶点上的 权函数 D ,可以直接用所有孤上对应的权和顶点上的权组成的有限维向量表示,因此 L,U, D 有时直接称为权向量,或简称权。由于给定有向图G = (V, A) 后,我们总是可 以在它的弧集合和顶点集合上定义各种权函数,所以流网络一般也直接简称为网络。
    . U% D! X% Q9 z  x
    . R. F) F$ l+ A( n/ D3 H. W在流网络中,弧(i, j) 的容量下界  和容量上界表示的物理意义分别是:通过该 弧发送某种“物质”时,必须发送的最小数量为 ,而发送的最大数量为 。顶点i ∈V 对应的供需量则表示该顶点从网络外部获得的“物质”数量( > 0时),或从该顶 点发送到网络外部的“物质”数量(< 0 时)。下面我们给出严格定义。' }; D- _8 H! s/ }/ _. E2 x

    4 c: C0 M) S' |' E  ?; ^' F1 C可行流(feasible flow)
    3 d: Y0 L/ x2 D: q
    ( c9 U, P, n3 c# {; R! ]
    # |+ X0 Q& w3 r
      u; R3 S' W6 a/ i0 b- _3 ^" t9 e" @
    可见,当 di > 0时,表示有di 个单位的流量从网络外部流入该顶点,因此顶点i 称 为供应点(supply node)或源(source),有时也形象地称为起始点或发点等;当di < 0 时,表示有|di | 个单位的流量从该顶点流失到网络外部(或说被该顶点吸收),因此顶 点i 称为需求点(demand node)或汇(sink),有时也形象地称为终止点或收点等;当 di = 0时,顶点i 称为转运点(transshipment node)或平衡点、中间点等。此外,根据 (1)可知,对于可行网络,必有* N" C' Y, |, q% x" y; o' O1 s

    . S0 A# A5 D. X3 L% M) Y
    1 {/ n8 e$ D( R. F1 k. q  G1 i8 [$ E) Y- y# `
    也就是说,所有节点上的供需量之和为 0 是网络中存在可行流的必要条件
    5 y0 g% F: f1 V# K% A* C: E8 m
    3 w. Z  t' M3 u# b6 a8 U  y
    - t' U- l+ r/ k, k1 k/ r( G
    8 ]3 A5 z9 _: Y% A& {- K: G( i
    8 I; P  x4 i) Q  \  g5 J3 y) S8 o1.2 最大流问题
    0 R* H: P- k% o9 {( A& q$ ~) l考虑如下流网络 N = (V, A,U,D):节点 s 为网络中唯一的源点,t 为唯一的汇点, 而其它节点为转运点。如果网络中存在可行流 f ,此时称流 f 的流量(或流值,flow value)为 (根据(3),它自然也等于 −  ),通常记为v 或v( f ) ,即0 @# ~* L: Z$ N) V  w  }7 Y
    . `& p' b  @* [4 h2 i

    $ i; o0 s3 D' W9 `5 N( I% u对这种单源单汇的网络,如果我们并不给定  和  (即流量不给定),则网络一 般记为 N = (s,t,V, A,U) 。最大流问题( maximum flow problem )就是在 N = (s,t,V, A,U) 中找到流值最大的可行流(即最大流)。我们将会看到,最大流问题 的许多算法也可以用来求解流量给定的网络中的可行流。也就是说,当我们解决了最大 流问题以后,对于在流量给定的网络中寻找可行流的问题,通常也就可以解决了。
    9 \  `7 C$ b0 L- U3 ^) [7 j; B- w' {
    用线性规划描述最大流问题" V6 `7 S% G; I/ C- ^
    因此,用线性规划的方法,最大流问题可以形式地描述如下:  K8 J, |; h7 O. k* b
    ' u: w  g% j7 a; x0 d% L2 J3 N' B
    & Q+ H$ q# C, Z7 b/ I7 t
    1 Z/ Z5 B; v( R% w
    定义】 如果一个矩阵 A 的任何子方阵的行列式的值都等于0,1或 −1,则称 A 是 全幺模的(totally unimodular TU,又译为全单位模的),或称 A 是全幺模矩阵。
    + V3 G7 g: M" j7 Y
    : i! R  ?7 ^3 }# k+ o- E& |: V! c整流定理& u+ C+ [% a. V, U
    【定理 7】(整流定理) 最大流问题所对应的约束矩阵是全幺模矩阵。若所有弧容量 均为正整数,则问题的最优解为整数解。 最大流问题是一个特殊的线性规划问题。我们将会看到利用图的特点,解决这个问 题的方法较之线性规划的一般方法要方便、直观得多。
    ( D8 o) x9 i/ q3 B7 d$ d
    ( V, \2 Z' I- X# ?7 k0 {' d2 @  f5 _1.3 单源和单汇运输网络
    ' L& l3 I! S+ W0 E' @. S0 L+ C' E/ V多源多汇网络 转化成单源单汇网络! |- _; e7 p% X5 f" Z3 C( R' U
    实际问题往往是多源多汇网络,为了计算的规格化,可将多源多汇网络G 化成单 源单汇网络G' 。设 X 是G 的源,Y 是G 的汇,具体转化方法如下:
    % _  W7 X0 ~% |( c; k+ }3 @: ]
    ( N- n- C8 Y3 w' Z; p4 y3 m. }: b(i)在原图G 中增加两个新的顶点 x 和 y ,令为新图G' 中之单源和单汇,则G 中 所有顶点V 成为G' 之中间顶点集。; K2 Q3 f( s1 C
    : _8 v0 q; G& U& f
    (ii)用一条容量为∞的弧把 x 连接到 X 中的每个顶点。8 q6 _7 O) j2 p! Y
    5 U/ [% M  v1 N- k. A
    (iii)用一条容量为∞的弧把Y 中的每个顶点连接到 y 。 G 和G' 中的流以一个简单的方式相互对应。若 f 是G 中的流,则由
    ' `' P; n$ {9 m8 t  c6 z# g  j  T& x! w0 U7 t+ H( k4 }6 y
    1 [& h( {9 B9 T5 U* T+ d/ N; ]

    4 L. |# s7 ~" {; Y4 Q- ~2 最大流和最小割关系割的容量/ g! C3 h6 {5 `8 j+ T
    & {9 g' W. x3 k  }
    # r. s' B) u! p
    5 X" a6 F8 Y) e: ]9 l3 Q7 s& W
    则在这条可增广轨上每条前向弧的流都可以增加一个量δ ,而相应的后向弧的流可减 少δ ,这样就可使得网络的流量获得增加,同时可以使每条弧的流量不超过它的容量, 而且保持为正,也不影响其它弧的流量。总之,网络中 f 可增广轨的存在是有意义的, 因为这意味着 f 不是最大流。( @# y8 R7 G, }

    ; {, ^. R/ e! a5 w* ^" C$ J3 最大流的一种算法—标号法( ^) L) M' ]1 g9 R' _/ Y' B5 }5 T
    标号法是由 Ford 和 Fulkerson 在 1957 年提出的。用标号法寻求网络中最大流的基 本思想是寻找可增广轨,使网络的流量得到增加,直到最大为止。即首先给出一个初始 流,这样的流是存在的,例如零流。如果存在关于它的可增广轨,那么调整该轨上每条 弧上的流量,就可以得到新的流。对于新的流,如果仍存在可增广轨,则用同样的方法 使流的值增大,继续这个过程,直到网络中不存在关于新得到流的可增广轨为止,则该 流就是所求的最大流。
    2 k8 U( x# r; Y3 q6 p( u6 m% I
    ( R9 W- b( c2 v: ]1 X这种方法分为以下两个过程:5 E- ~! I" P5 Q

    ! u" @$ p2 e8 w% VA.标号过程:通过标号过程寻找一条可增广轨。1 t' {" h  r' N! C- Q& B# C, F

    ) M. w% |4 P2 N; W3 u* {* W0 LB.增流过程:沿着可增广轨增加网络的流量。
    2 ]; K! r( B2 E! c7 M
    9 o' n8 m/ M9 i3 U4 x这两个过程的步骤分述如下。7 ^' T& @, g0 U2 z

    ( j! _. X* C' ~$ ]. v(A)标号过程:
    & N: Q. Z; M/ g5 f8 {$ Z" I% x
    8 N& R. w, Z! w/ u8 y. B0 L
    : b  |3 t  w1 _" B2 q, l+ s0 O! P' |( k
    (B)增流过程# O& H3 {1 u* `

    9 R+ C7 O; l* ~* l" Q6 |. O网络最大流 x 的求解步骤
    1 P* x8 f1 W* O$ q2 E% p) v9 b2 ]求网络 N = (s,t,V, A,U) 中的最大流 x 的算法的程序设计具体步骤如下:
    / T9 p* Q/ S6 V2 v6 E9 b
    9 X- p1 ]$ j0 B) ^% v对每个节点 j ,其标号包括两部分信息 (pred( j),maxf(j)), u, f! N4 ?; _) j5 x

    5 O: r0 O0 o  ~3 F+ n该节点在可能的增广路中的前一个节点 pred( j) ,以及沿该可能的增广路到该节点为止 可以增广的最大流量 maxf( j)。' g3 C5 O9 s/ [6 L" X  L! {% o
    ( a2 k, a; N. s% K  T, |

    2 i0 _) c/ {6 J2 t
    8 K% M7 }# n+ g7 G

    并将 j 加入 LIST 中。

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


    ! x( R0 J1 r8 x( [! S& Z8 J4 F6 d1 d, a+ c8 V9 x

      c& K- x! s5 c9 B5 u; _解 编写程序如下:9 B8 {: m, z' W1 f% f9 L
    4 V5 N* G& O3 T, i
    clc,clear
    " S. v1 m. M+ x8 g; Y& s1 Qu(1,2)=1;u(1,3)=1;u(1,4)=2;u(2,3)=1;u(2,5)=2;
    8 k  ~/ m' M8 n! A% f+ Q' Ku(3,5)=1;u(4,3)=3;u(4,5)=3;
    & _3 F. R/ U; [+ W( Qf(1,2)=1;f(1,3)=0;f(1,4)=1;f(2,3)=0;f(2,5)=1;: d7 E( R' S, M! U6 _
    f(3,5)=1;f(4,3)=1;f(4,5)=0;1 e6 _5 M* U! R) ~1 V9 J
    n=length(u);list=[];maxf(n)=1;
    0 [- s: D* Y) A$ Q+ W, zwhile maxf(n)>09 n8 x* n9 [) x  K) ^6 b2 Z5 U
    maxf=zeros(1,n);pred=zeros(1,n);, k. w1 N/ o/ O1 g) D
    list=1;record=list;maxf(1)=inf;0 |  K# \' w+ Q0 o9 I. a
    % list是未检查邻接点的标号点,record是已标号点" Z- b5 w8 q3 f9 l, J
    while (~isempty(list))&(maxf(n)==0)
    1 l  R7 t% H) V  A    flag=list(1);list(1)=[];
    . Q8 i+ @( b+ p    label1= find(u(flag,-f(flag,);- k' K# Z8 ~" I% h. }! W
        label1=setdiff(label1,record);
    5 V1 L. d0 x- |: H    list=union(list,label1);
    : a2 }, E2 `8 ^6 o8 M( e    pred(label1)=flag;9 K: q% L/ q% s/ N- t
        maxf(label1)=min(maxf(flag),u(flag,label1)...
    - l  a& e& ]& N: M( ]1 y    -f(flag,label1));
    8 Y: E* V' U* G    record=union(record,label1);
    3 D: Q0 o5 x" S# T/ T    label2=find(f(:,flag));
    8 f: r( w; r( F& @1 T    label2=label2';
    # X8 T+ a5 o4 s* v  _: p3 `    label2=setdiff(label2,record);
    ! C: n; a% O: t" Z    list=union(list,label2);
    * p5 w- D9 L7 s* }5 u5 L    pred(label2)=-flag;
    ' W. [: g5 d# t) K/ ^! y    maxf(label2)=min(maxf(flag),f(label2,flag));
    ' i: ~& D4 N9 f( T! O' |    record=union(record,label2);
    2 X4 x- |- @' r% l9 Z# r( b6 s0 M end4 A0 p- {7 N% Y$ ~* x1 W: V4 D
         if maxf(n)>00 |7 E5 y  p1 ?/ O  E* @
            v2=n; v1=pred(v2);; X5 j  B3 ?5 C3 b" C% N4 x
            while v2~=1( C& p& o9 Z7 k0 q9 C  H# A
                if v1>0( A4 e/ k. M, C1 }
                    f(v1,v2)=f(v1,v2)+maxf(n);
    9 K  S1 E% Y! G$ K3 q; B            else
    0 K: f3 I! w1 O! e% m8 u                v1=abs(v1);
    * y& M  q8 x  h  T5 w. c                f(v2,v1)=f(v2,v1)-maxf(n);3 R  J  M0 f  c& `; x0 V+ W
                end
    / W- [, U; |& `' ^6 v            v2=v1; v1=pred(v2);
    ; m& j) |. s3 n: ^) s) f        end/ R, E7 b! L5 {9 f  N) s! ~
        end
    . g1 x- n0 b  ~% pend
    6 K2 C9 N  W. t2 yf ) k; f2 j4 H- X& B6 `4 h
    例18 现需要将城市 s 的石油通过管道运送到城市t ,中间有4个中转站  v1 ,v2 ,v3 和  v4 ,城市与中转站的连接以及管道的容量如图7所示,求从城市 s 到城市t 的最大流。4 t0 V1 S+ o  y
    ) |; n% h+ s+ q9 Q

    6 h# {5 a2 i% o3 G- y& r0 a& J/ Y1 G5 `
    : d5 y% F3 U# E, e
    解 使用最大流的数学规划表达式,编写LINGO程序如下:% n1 N$ z1 u! ~3 o; @

    - q* b6 Y/ B* f( i7 Q9 M) G5 ?. omodel:3 F- T1 u% I) p
    sets:
    8 l  z3 C9 ~# `nodes/s,1,2,3,4,t/;
    9 M6 g, z, _* Garcs(nodes,nodes)/s 1,s 3,1 2,1 3,2 3,2 t,3 4,4 2,4 t/:c,f;4 k6 |, _& E4 q  @# Q' l. u
    endsets
    % p0 U% I( ~0 c- G- b- D& o6 Pdata:: y3 ?1 c+ ~) f1 ~0 F8 }) W
    c=8 7 9 5 2 5 9 6 10;
    / ~6 B! e' ^1 k2 |enddata
    5 ]  Y2 F* X% n2 b  e3 |7 @n=@size(nodes); !顶点的个数;: r* ?1 L0 ^* w; V* Z# L6 G
    max=flow;  Z. G$ T4 }. Q) e3 t: k! i$ ]
    @for(nodes(i)|i #ne#1 #and# i #ne# n:
    6 {0 r4 |" g6 a; L! T    @sum(arcs(i,j):f(i,j))=@sum(arcs(j,i):f(j,i)
    9 Y  Z5 b% ?1 F% K@sum(arcs(i,j)|i #eq# 1:f(i,j))=flow;
    " c0 V- j9 d' \& @7 \- ^1 J@sum(arcs(i,j)|j #eq# n:f(i,j))=flow;
    5 D* L# i4 R, D3 k$ c@for(arcsbnd(0,f,c));
    5 ^8 b3 |/ ?6 \2 O1 }2 V3 p4 Send ! e$ F9 d7 w3 E! K/ ^
    3 L0 \2 M& F. [" Q
    在上面的程序中,采用了稀疏集的编写方法。下面介绍的程序编写方法是利用赋权邻 接矩阵,这样可以不使用稀疏集的编写方法,更便于推广到复杂网络。
    % y+ @9 v/ F) k' y
    5 {, V  p6 }$ W. X, z6 J) tmodel:$ ~& ~) j0 }7 B4 v# p4 Q6 d
    sets:! H2 z: L% g# ^+ D( X) C2 x
    nodes/s,1,2,3,4,t/;
    ! U5 t% S  E2 X0 y: Sarcs(nodes,nodes):c,f;& ^' u. f6 O$ W  @1 j) ^, E
    endsets  G4 p) s# i1 O6 u6 H
    data:
    + |; t& f% N5 t7 }7 s7 P& [c=0;
    2 L6 @7 @: h  C6 Y# B7 }@text('fdata.txt')=f;4 I( q: d: _9 }  X( N1 Z$ d
    enddata
    * p: j" d" J% Scalc:" o4 ~) n8 p* K  U5 }: e9 B9 j$ o
    c(1,2)=8;c(1,4)=7;# q4 L: k0 w9 P& S( @
    c(2,3)=9;c(2,4)=5;6 J0 b9 @5 Q* b( y: I
    c(3,4)=2;c(3,6)=5;2 D+ r$ k8 e; o
    c(4,5)=9;c(5,3)=6;c(5,6)=10;7 e- d$ ]! S" e) `
    endcalc
    : j) ]3 p9 ^* u0 |) G( wn=@size(nodes); !顶点的个数;
    ) C7 T8 z! q/ f7 g$ ]max=flow;: ^6 @7 H( F6 g- |! U
    @for(nodes(i)|i #ne#1 #and# i #ne# n:
    0 _  I; P/ {9 }/ u- Q    @sum(nodes(j):f(i,j))=@sum(nodes(j):f(j,i)));) S- r) W% k% t5 o( e' v
    @sum(nodes(i):f(1,i))=flow;
      u+ m6 a/ H: _( D1 Q@sum(nodes(i):f(i,n))=flow;% @! Q) p" l/ D6 b
    @for(arcsbnd(0,f,c));) d' D# V" u5 g0 k
    end$ {0 ~- p: L* z* j5 B
    4 F6 `$ \6 h' B# X- x2 X# z0 j( R5 t
    ————————————————9 @" ^1 D# W6 ~! e4 J
    版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。0 Y; _6 d7 K$ t
    原文链接:https://blog.csdn.net/qq_29831163/article/details/89786313- n$ b, p# G" Y9 x) o

    0 p# h( O: y8 |9 `( @8 D; G
    - f0 m% u. L: x6 Q% U  t& l* }
    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:41 , Processed in 0.398176 second(s), 50 queries .

    回顶部