最大流之sap算法
若有向图G = (V , E)满足下列条件:
1、有且仅有一个顶点S,它的入度为 0 ,这个顶点称为源点。
2、有且仅有一个顶点T,它的出度为 0 ,这个顶点称为汇点。
3、每一条弧都有一个非负数,叫做这条边的容量,边(Vi , Vj)的容量用 Cij 来表示。
则此有向图称为网络流图,记为 G = ( V , E , C) ;
对于网络流图G中,每一条弧( i , j )都给定一个非负数Fij,对于一组数据满足下面三个条件时,称为可行流;
1、对于每条弧都有 Fij < Cij ;
2、出了源点S和汇点T之外,中间任意点流量守恒,即输入流等于输出流;
3、对于源点S和汇点T,从S出去多少就会从T流入多少;
假如有这么一条路,从源点开始,一直一段一段的连到了汇点,并且这条路上的每一段满足Fij < Cij ,则称这条路为增广路;
当找不到增广路时,当前流量就是最大流。
寻找增广路时可以简单地从源点开始做bfs,并不断修改这条路上的最大流。
但事实上并不是这么简单,上面所说的增广路还不是很完整,中间还存在一些细节问题,例如:

我们通过bfs遍历后得到第一条增广路 1 - 2 - 3 - 4 ,然后就不存在增广路径了,其实并不是这样,这个网络流的最大流明显为 2 ,我们可以是使用一个叫反向边的概念来解决这个问题,如图:

这样就解决了增广路算法中的一些细节问题;
加入一个网络图中有4个点,5条边组成。如下:
5 4
1 2 40
1 4 20
2 4 20
2 3 30
3 4 10
求最大流是多少?
下面给出相应的代码:
#include<iostream>
#include<queue> using namespace std ; int n , m ; int map[210][210] ; int path[210] ; int flow[210] ; int bfs() {
queue<int> q ;
memset(path,-1,sizeof(path)) ;
path[1] = 0 ;
flow[1] = (1<<30) ;
q.push(1) ;
while(!q.empty()) {
int t = q.front() ;
q.pop() ;
if(t == m) break ;
for(int i = 2 ; i <= m ; i++)
if(path[i] == -1 && map[t][i]) { // 该路径没有被访问过
flow[i]=flow[t]<map[t][i]?flow[t]:map[t][i]; // 该路径最小流量
q.push(i) ;
path[i] = t ; // 存储路径
}
}
if(path[m] == -1)
return -1 ;
return flow[m] ;
} void Edmonds_Karp() {
int max_flow = 0 , floww ;
while((floww=bfs())!=-1) {
max_flow += floww ;
int s , t ;
t = m ;
while(t != 1 ) {
s = path[t] ;
map[s][t] -= floww ;
map[t][s] += floww ;
t = s ;
}
}
cout << max_flow << endl ;
} int main() {
while(cin >> n >> m) {
memset(map,0,sizeof(map)) ;
while(n--) {
int u , v , cost ;
cin >> u >> v >> cost ;
map[u][v] += cost ;
}
Edmonds_Karp() ;
}
return 0 ;
}
2S@0{S1EBG9MUA5YG4.jpg)
2S@0{S1EBG9MUA5YG4.jpg)
最大流之sap算法的更多相关文章
- HDU1532 Drainage Ditches —— 最大流(sap算法)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1532 Drainage Ditches Time Limit: 2000/1000 MS (Java/ ...
- 最大流的SAP算法模板
明天补充~~~先上代码 #include<iostream> #include<string> #include<queue> #include<vector ...
- 网络流 最大流—最小割 之SAP算法 详解
首先引入几个新名词: 1.距离标号: 所谓距离标号 ,就是某个点到汇点的最少的弧的数量(即边权值为1时某个点到汇点的最短路径长度). 设点i的标号为level[i],那么如果将满足level[i]=l ...
- hdu3572Task Schedule 最大流,判断满流 优化的SAP算法
PS:多校联赛的题目质量还是挺高的.建图不会啊,看了题解才会的. 参考博客:http://blog.csdn.net/luyuncheng/article/details/7944417 看了上面博客 ...
- POJ 2455 网络流 基础题 二分+网络流 dicnic 以及 sap算法
Secret Milking Machine Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 8189 Accepted: ...
- ACM/ICPC 之 网络流入门-Ford Fulkerson与SAP算法(POJ1149-POJ1273)
第一题:按顾客访问猪圈的顺序依次构图(顾客为结点),汇点->第一个顾客->第二个顾客->...->汇点 //第一道网络流 //Ford-Fulkerson //Time:47M ...
- StreamDM:基于Spark Streaming、支持在线学习的流式分析算法引擎
StreamDM:基于Spark Streaming.支持在线学习的流式分析算法引擎 streamDM:Data Mining for Spark Streaming,华为诺亚方舟实验室开源了业界第一 ...
- hdu2883 最大流,判断满流 优化的SAP算法
这是09年的多校联赛题目,比10年的难度要大.如果没做过hdu3572,建议先去做.有了解题思维再来做这题. 这题与hdu3572类似.但是1 <= si < ei <= 1,000 ...
- 关于最大流的EdmondsKarp算法详解
最近大三学生让我去讲课,我就恶补了最大流算法,笔者认为最重要的是让学弟学妹们入门,知道算法怎么来的?为什么是这样?理解的话提出自己的改进,然后再看看Dinic.SAP和ISAP算法….. 一.概念引入 ...
随机推荐
- 原来ipad的浏览器也可以直接clip到evernote
今天才发现是有方法通过邮件方式保存ipad上浏览的内容到evernote,之前以为要反复切换app来做到. 只要在toread.cc登记evernote对应帐号的邮箱,就可以根据toread返回到ev ...
- 面向对象程序设计-C++_课时13初始化列表
构造函数设置成员初值方法有两种:一种是在函数体内赋值,另一种是采用初始化列表的形式. 初始化列表BETTER 函数体内赋值 类名::类名(形参1,形参2,...形参n) { 数据成员1=形参1; 数据 ...
- DataReader转泛型
实体类的字段类型要和数据库一致,不然可能会出现错误. /// <summary> /// DataReader转泛型 /// </summary> /// <typepa ...
- MD5和sha1加密算法
在很多电子商务和社区应用中,我们都要存放很多的客户的资料,其中包括了很多的隐私信息和客户不愿被别人看到的信息,当然好有客户执行各种操作的密码,此时就需要对客户的信息进行加密再存储,目前有两种比较好的加 ...
- C# OR/Mapping 数据处理模式学习
为什么要提出O/R Mapping概念 程序语言已经由面向过程的模型全面转向为面向对象的模型,UML的出现更加革新了软件开发方法论.然而数据库模型却从未随着开发语言的进步而随之革新,仍然使用面向关系的 ...
- md笔记——微信JS接口
微信js接口 隐藏微信中网页右上角按钮 document.addEventListener('WeixinJSBridgeReady', function onBridgeReady() { Weix ...
- Android学习笔记_点九绘图与软键盘和事件传递
最近项目里遇到的几个小问题,以前只是用吗没有深入看过,现在总结到一起,防止以后这种小问题占用太多时间.还是通过网上别人总结的很多博客学习了,挑选出最易懂明了的. 还有leader很小的问题都不放过,亲 ...
- LDAP基础
超级好的LDAP文章: Linux下基于LDAP统一用户认证的研究 : http://chenguang.blog.51cto.com/350944/285602利用LDAP实现windows和Lin ...
- NSURLConnect 的简单实用(iOS8淘汰)
Demo_1 NSRULConnection NSRULConnection 苹果公司在ios8已经抛弃了,但是我还是要讲一下,因为这和后面的NSSession有着密切的联系 下面开始使用步骤: 1. ...
- UICollectionView 简单的使用和注意事项
UICollectionView 在创建的时候,要给它一个UICollectionViewFlowLayout (不然会崩溃),就像tableview一样,也要为它注册自定义的cell. UIColl ...