一般增广路方法求网络最大流(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,表示发电 ...
随机推荐
- 浅谈CSS3 box-reflect 属性
今天说一下 CSS3的box-reflect属性,也就是倒影特效. 语法: box-reflect:包括3个值. 1. direction 定义方向,取值包括 above . below . left ...
- [HMLY]11.iOS函数式编程的实现&&响应式编程概念
简介 本篇主要回顾一下--iOS函数式编程 && 响应式编程概念 ,如何一步步实现函数式编程的过程,对阅读Masonry && SnapKit源码有一定的帮助. 作为一 ...
- postgresql----serial类型和序列
postgresql序列号(SERIAL)类型包括smallserial(smallint,short),serial(int)和bigserial(bigint,long long int),不管是 ...
- C# 匿名方法和拉姆达表达式
有时候,我们需要封装一组数据,只有数据,没有方法,并且只用于当前程序,不需要在项目间重用,这时候,如果是传统的使用类来封装的话,大概会是下面这种样子: internal class SomeData ...
- java 的序列化
(1) 首先是java自己内部实现的对象序列化机制 其实就是ObjectInputStream 和 ObjectOutputStream 首先实现一个实体对象 记住必须实现Serializable ...
- usaco月赛,2017.1总结
T1:跳舞的奶牛 大致题意:一个体积为k的舞台能够同时容纳k只奶牛一起跳舞,他们每头奶牛的跳舞时间不同,如果有一只奶牛跳完了第k+1头奶牛就会立刻上场跳舞,当所有奶牛跳完舞以后我们认为这次表演结束.现 ...
- Hex Workshop(16进制编辑利器) 6.7.2绿色版
软件名称: Hex Workshop 6.7.2绿色版(16进制编辑利器) 软件语言: 简体中文 授权方式: 免费软件 运行环境: Win 32位/64位 软件大小: 1.8MB 图片预览: 软件简介 ...
- Linux、GUN/Linux、GUN、GPL以及各个发行版本详细介绍
学习Linux很久了,却对GUN,Linux,Linux发行版等无所了解,是不是觉得很对不起自己啊.呵呵,所以我就在网上找了些资料,总结在一起,还算是比较能说明问题的. 什么是Linux? 也许很多人 ...
- EmbossMaskFilter BlurMaskFilter 学习
MaskFilter类可以为Paint分配边缘效果.对MaskFilter的扩展可以对一个Paint边缘的alpha通道应用转换.Android包含了下面几种MaskFilter: BlurMaskF ...
- APP模板框架
HTML页面 <!DOCTYPE html><html lang="en"><head> <meta charset="UTF- ...