一般增广路方法求网络最大流(Ford-Fulkerson算法)
/*
Time:2015-6-18
接触网络流好几天了
写的第一个模版————Ford-Fulkerson算法
作用:求解网络最大流
注意:源点是0 汇点是1 如果题目输入的是1到n 请预处理减1
*/
#include<cstdio>
#include<cstring>
#include<cmath>
#include<queue>
#include<algorithm>
using namespace std; const int INF = 0x7fffffff;//无穷大
const int maxn = + ;//这里可以设置结点的数量
int n, m;
int flag[maxn], pre[maxn], alpha[maxn];
int c[maxn][maxn], f[maxn][maxn];
queue<int>Q; int main()
{
int i, j, u, v, cc, ff;
scanf("%d%d", &n, &m);
for (i = ; i<n; i++) for (j = ; j<n; j++) c[i][j] = INF, f[i][j] = INF; //初始化不存在弧
for (i = ; i<m; i++)
{
scanf("%d%d%d%d", &u, &v, &cc, &ff);//输入弧的起点,弧的终点,弧的容量,弧的流量 //解决重边问题
if (c[u][v] == INF) { c[u][v] = cc; f[u][v] = ff; }
else { c[u][v] += cc; f[u][v] += ff; }
}
//0是源点 n-1汇点
int startt, endd;
startt = ;
endd = n - ;
while ()
{
while (!Q.empty()) Q.pop();
memset(flag, -, sizeof(flag));
memset(pre, -, sizeof(pre));
memset(alpha, -, sizeof(alpha));
flag[startt] = ;//源点已标号 但是未检查邻接顶点
pre[startt] = ;//源点从自己推过来
alpha[startt] = INF;//源点可以发出INF的流量
Q.push(startt);
while ((!Q.empty()) && flag[endd] == -)
{
int h = Q.front(); Q.pop();
for (i = ; i<n; i++)
{
//前向弧
if (c[h][i] != INF)//有路
{
if (f[h][i]<c[h][i])//不饱和
{
if (flag[i] == -)//i顶点未标号
{
flag[i] = ;//i顶点已标号 但是未检查邻接顶点
pre[i] = h;//i从h推过来
//alpha[i]取决于alpha[h]与c[h][i]-f[h][i]的较小值
if (c[h][i] - f[h][i] <= alpha[h]) alpha[i] = c[h][i] - f[h][i];
else alpha[i] = alpha[h];
Q.push(i);//i顶点进入队列 等待检查邻接顶点
}
}
}
//后向弧
if (c[i][h] != INF)//有路
{
if (f[i][h]>)//非零流弧
{
if (flag[i] == -)//i顶点未标号
{
flag[i] = ;//i顶点已标号 但是未检查邻接顶点
pre[i] = -h;//i从h推过来 标号为- 意思是后向弧
//alpha[i]取决于alpha[h]与f[i][h]的较小值
if (alpha[h] <= f[i][h]) alpha[i] = alpha[h];
else alpha[i] = f[i][h];
Q.push(i);//i顶点进入队列 等待检查邻接顶点
}
}
}
}
flag[h] = ;//h顶点已标号,并且已经检查所有的邻接顶点
}
if (flag[endd] == - || alpha[endd] == ) break; //已经不存在增广路,不再寻找
int a = alpha[endd];//可改进量
int now = endd;
while ()
{
if (now == ) break;
if (pre[now] >= )
{
f[pre[now]][now] += a;
now = pre[now];
}
else if (pre[now]<)
{
f[now][-pre[now]] -= a;
now = -pre[now];
}
} }
for (i = ; i<n; i++)
for (j = ; j<n; j++)
if (f[i][j] != INF)
printf("%d --> %d : %d\n", i, j, f[i][j]);
int maxflow = ;
for (i = ; i<n; i++) if (f[][i] != INF) maxflow += f[][i];
printf("maxflow = %d\n", maxflow);
return ;
}
一般增广路方法求网络最大流(Ford-Fulkerson算法)的更多相关文章
- PIGS POJ - 1149网络流(最短增广路---广搜) + 建图
题意: 第一行输入m和n,m是猪圈的数量,n是顾客的数量,下面n行 第 i+1行表示第i个顾客 , 输入第一个数字表示有几把猪圈的钥匙,后面输入对应的猪圈,最后一个数字输入顾客想买几头猪. 建图: 设 ...
- POJ-1273-Drainage Ditches 朴素增广路
Drainage Ditches Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 70588 Accepted: 2743 ...
- hdu 3549 Flow Problem【最大流增广路入门模板题】
题目:http://acm.hdu.edu.cn/showproblem.php?pid=3549 Flow Problem Time Limit: 5000/5000 MS (Java/Others ...
- 【Luogu】P3381最小费用最大流模板(SPFA找增广路)
题目链接 哈 学会最小费用最大流啦 思路是这样. 首先我们有一个贪心策略.如果我们每次找到单位费用和最短的一条增广路,那么显然我们可以把这条路添加到已有的流量里去——不管这条路的流量是多大,反正它能 ...
- hdu 3549 Flow Problem(增广路算法)
题目:http://acm.hdu.edu.cn/showproblem.php?pid=3549 模板题,白书上的代码... #include <iostream> #include & ...
- Power Network (最大流增广路算法模板题)
Time Limit: 2000MS Memory Limit: 32768K Total Submissions: 20754 Accepted: 10872 Description A p ...
- HDU3549 Flow Problem(网络流增广路算法)
题目链接. 分析: 网络流增广路算法模板题.http://www.cnblogs.com/tanhehe/p/3234248.html AC代码: #include <iostream> ...
- 网络流初步:<最大流>——核心(增广路算法)(模板)
增广路的核心就是引入了反向边,使在进行道路探索选择的时候增加了类似于退路的东西[有一点dp的味道??] 具体操作就是:1.首先使用结构体以及数组链表next[ MAXN ]进行边信息的存储 2.[核心 ...
- POJ 1459 Power Network(网络最大流,dinic算法模板题)
题意:给出n,np,nc,m,n为节点数,np为发电站数,nc为用电厂数,m为边的个数. 接下来给出m个数据(u,v)z,表示w(u,v)允许传输的最大电力为z:np个数据(u)z,表示发电 ...
随机推荐
- iOS开发-内存管理
内存管理 对于这篇呢,其实现在都是ARC模式,正常状态下基本不用我们去手动释放内存,所以如果不是要面试呀.装逼或者扎实功底的,就先别看了或者了解下即可,因为像面试时,有些面试官想看你的基础时,就有些人 ...
- AngularJS2之Angular正式初探
前言:angular的官方教程真的不错.强烈推荐!!!] 按照环境搭建教程新建一个项目: 项目的结构如下: 其中package.json指示node需要安装的插件(npm install指令会安装的插 ...
- 自定义底部导航栏(tabBar)
前言如果大家用过微信提供的tabBar就会发现,他的tabBar有很大的局限性.暂且不说样式局限性了,他提供的app.json配置文件中没有function.这也就意味着使用它提供的这个组件,你只能用 ...
- [SQL基础教程] 5-1视图
[SQL基础教程] 5-1视图 视图和表 从SQL角度看视图就是一张表 视图与表的差别 表保存了实际的数据,视图保存的是SELECT语句: 视图的优点 节省存储空间: 将常用的Select 语句保存成 ...
- javaScript设计模式之常用工厂模式
工厂函数 定义 由一个工厂对象决定创建某一种产品对象类的实例,主要用来创建同一类对象. 使用场景 比如说你是到一个买宠物的店,里面有很多不同的宠物,你只需要说出宠物的名字给店员就行了. // 狗的类 ...
- CPU和GPU的区别
个人认为CPU和GPU各有自己的适应领域.CPU(Central Processing Unit)计算核心较少,通常是双核.四核.八核,但是拥有大量的共享缓存.预测.乱序执行等优化,可以做逻辑非常复杂 ...
- C语言指针、地址、赋值三者含义
先来一个观点.大家先看看对不对 按:在CSDN论坛上,有位坛友提到这个问题: ==================================== 先看一段代码: #include<stdi ...
- MVC JsonResult
public JsonResult GetJson() { var res = new JsonResult(); res.Data = new {isSucceed = true, returnMs ...
- payoneer注册充值提现海外收款费用官方解答
从事海外贸易的朋友,会发现收款是一大难题.Paypal是老牌支付平台,但费率高昂.其实,Payoneer是新兴的收款工具,非常适合做外贸的卖家使用,提现灵活,费率低,免费注册账号后,可直接获得美国.英 ...
- navicat导出数据结构及数据
右键选中数据库-->右键->数据传输->高级->选中所需导出的表->选择文件