山大《运筹学》课件06图与网络分析-6最大流问题_第1页
山大《运筹学》课件06图与网络分析-6最大流问题_第2页
山大《运筹学》课件06图与网络分析-6最大流问题_第3页
山大《运筹学》课件06图与网络分析-6最大流问题_第4页
山大《运筹学》课件06图与网络分析-6最大流问题_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、第六节 最大流问题最大流最小割定理 基本概念 主要定理最大流算法 算法步骤 算法复杂性基本概念给定有向网络G=(N,A,C),cij表示弧(i,j)A的容量,G有一个发点s和一个收点t (s,t N)。令xij=通过弧(i,j)的流量 (6.6.1)显然有0 xijcij (6.6.2)另外,流x=(xij)要遵守点守恒规则,即可行流:满足(6.6.1)和守恒方程(6.6.2)的流,简称为(s,t)-流基本概念设P是G中从s到t的无向路,则P的前向弧(i,j)是指其方向从s到t的弧;否则称为P的后向弧流x=(xij)的增广路P:P的每个前向弧(i,j)有xij0(s,t)-割:弧割(S,T),

2、其中sS,tT割(S,T)的容量:续主要定理定理6.6.1(增广路定理) 一个可行流是最大流当且仅当不存在关于它的从s到t的增广路。 定理6.6.2(整流定理) 如果网络中所有弧容量是整数,则存在值为整数的最大流。 定理6.6.3(最大流最小割定理) 一个(s,t)-流的最大值等于(s,t)-割的最小容量。 证明证明提示最大流算法的步骤第1步(开始) 令x=(xij)是任意整数可行流,可能是零流,给s一个永久标号(-,)。 第2步(找增广路)(2.1) 如果所有标号都已经被检查,转到第4步。(2.2) 找一个标号但未检查的点i,并做如下检查,对每一个弧(i,j),如果xijcij且j未标号,则

3、给j一个标号(+i,(j),其中(j)=mincij-xij,(i);对每一个弧(j,i),如果xij0且j未标号,则给j一个标号(-i,(j),其中(j)=minxji,(i)。(2.3) 如果t已被标号,转到第3步;否则,转到(2.1)。最大流算法的步骤第3步(增广) 由点t开始,试用指示标号构造一个增广路,指示标号的正负则表示通过增加还是减少弧流量来增大流值。抹去S点以外的所有标号,转到第2步。第4步(构造最小割) 这时现行流是最大的,若把所有标号点的集合记为S,所有未标号点的集合记为T,便得到最小容量割(S,T),计算完成。 续例最大流算法的复杂性设弧数为m,每找一条增广路最多需要进行2m次弧检查。如果所有弧容量都是整数,则最多需要v次增广,其中v是最大流值。所以,总的计算量为O(mv)。注:此算法的时间复杂性与最大流值v有关,

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论