一般增广路方法求网络最大流(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,表示发电 ...
随机推荐
- window7环境下VMWare自定义安装Linux虚拟机完全教程
1.首先准备好以下工具和安装包,最好到官网下载: VMWare 8.x,注意版本不易过高,因为很多时候会出现和Linux镜像不兼容的情况,下载地址:http://www.vmware.com/cn.h ...
- JNDI中 java:comp/env 的理解
J2EE 上下文环境变量前缀,一般有如下几种:java:/comp/env/jdbcjava:/comp/env/urljava:/comp/env/mailjava:/comp/env/jms在部署 ...
- 手工场景--controller--场景设计、场景监控、运行场景
场景设置: 1.设置界面 2.全局设置. A:初始化: B:启动用户: C:
- OSI模型第一层物理层
纪念我曾今热爱的数通(^o^). 物理层 一句话概述: OSI的第一层,它虽然处于最底层,却是整个开放系统的基础.物理层为设备之间的数据通信提供传输媒体及互连设备,为数据传输提供可靠的环境. 常见设备 ...
- apk反编译查看源码
1.将apk解压
- iOS Size Class使用
iOS8和iPhone6发布已经过去蛮久了,广大的果粉终于迎来了大屏iPhone,再也不用纠结为大屏买三星舍苹果了-但是对于iOS开发人员来说,迎来了和Android开发开发一样的问题->各种屏 ...
- FZU 2243 Daxia like uber
枚举,最短路. 求出5个点出发的最短路,然后枚举一下这些点之间走的顺序. #pragma comment(linker, "/STACK:1024000000,1024000000" ...
- Facebook 在page添加自己开发的app
最初接到的需求是,在facebook主页中嵌入一个类似这样领取游戏礼包的页面. 一开始连facebook开发者中心在哪里都不知道,在万能的搜索框里面找到static html之类的第三方应用,但是这样 ...
- 淘宝npm镜像使用方法
镜像使用方法(三种办法任意一种都能解决问题,建议使用第三种,将配置写死,下次用的时候配置还在): 通过config命令npm config set registry https://registry. ...
- Java中的native关键字与JNI
一.先说一下大致的意思: jdk提供的类库源代码中有一些方法没有实现,这些方法前有native关键字,如object类中的 : native Object clone() throws CloneNo ...