一般增广路方法求网络最大流(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,表示发电 ...
随机推荐
- 2015 ACM / ICPC 亚洲区域赛总结(长春站&北京站)
队名:Unlimited Code Works(无尽编码) 队员:Wu.Wang.Zhou 先说一下队伍:Wu是大三学长:Wang高中noip省一:我最渣,去年来大学开始学的a+b,参加今年区域赛之 ...
- centos6.8 搭建nginx+uwsgi+Flask
1.安装 yum install nginx -y pip3 install uwsgipip3 install Flask 2.uwsgi配置(保存/etc/uwsgi.ini,run:uwsgi ...
- Docker集群实验环境布署--swarm【2 搭建本地镜像仓库】
在10.40.100.148上 # docker run -d -p 5000:5000 --restart=always --name docker-registry.venic.com - ...
- iOS 让UIButton根据文字内容自动计算宽高
Xcode自带的UIButton控件是没有办法根据文字内容计算自身的宽和高的,下面演示一下问题, 我用代码方式创建一个UIButton,并且设置了一些属性,下面看一下效果图 一切都是这么的美好,跟我们 ...
- BIEE基本函数
一,TRIM ,去除空字符 TRIM(EXPR) SUBSTRING("UT TIME"."月份" FROM 6 FOR 2) 1.AGGREGATE AT 此 ...
- hdu1116回溯N皇后问题
题目连接 经过思考,不难发现:恰好N个皇后放在不同行不同列,那么是不是可以转换成N个皇后所在行分别确定(一人一行)的情况下对她们的所在列的枚举. 也就是列的全排列生成问题,我们用c[x]表示x行皇后的 ...
- gulp 安装步骤
第一步:安装node 搭建node环境:进入官网 http://nodejs.org ,然后点击的绿色的 install 按钮,下载完成后直接运行程序. 第二步:使用命令行 (1)输入指令:node ...
- JavaScript实现360度全景图片展示效果
全景拍摄:所谓“全景拍摄”就是将所有拍摄的多张图片拼成一张全景图片.它的基本拍摄原理是搜索两张图片的边缘部分,并将成像效果最为接近的区域加以重合,以完成图片的自动拼接.现在的智能手机也基本带这个功能. ...
- ansible module
模块是一个独立的, 可以复用的脚本, 它可以被anisible API, Ansible 或者ansible-playbook使用. 在模块退出之前, 它通过输出一个json字符串到标准输出从而反 ...
- Ubuntu14.04 bind9配置
apt-get install bind9 配置域名: cn.archive.ubuntu.com 对应IP: 10.60.233.244 vim /etc/bind/name.conf.defaul ...