ACM/ICPC 之 网络流入门-EK算法(参考模板)(POJ1273)
基于残留网络与FF算法的改进-EK算法,核心是将一条边的单向残留容量的减少看做反向残留流量的增加。
//网络流
//EK算法
//Time:16Ms Memory:348K
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<queue>
using namespace std; #define MAX 205
#define INF 0x3f3f3f3f int n, m;
int res[MAX][MAX];
int pre[MAX];
bool v[MAX]; bool bfs(int s,int t) //寻找s->t的增广路
{
memset(v, false , sizeof(v));
memset(pre, -1, sizeof(pre));
queue<int> q;
q.push(s);
v[s] = true;
while (!q.empty()) {
int cur = q.front(); q.pop();
for (int i = 1; i <= n; i++)
{
if (!v[i] && res[cur][i])
{
pre[i] = cur;
if (i == t) return true; //找到增广路
q.push(i); v[i] = true;
}
}
}
return false;
} int EK(int s, int t)
{
int maxFlow = 0;
while (bfs(s, t))
{
int mind = INF; //最小可改进量
for (int i = t; i != s; i = pre[i])
mind = min(mind, res[pre[i]][i]);
for (int i = t; i != s; i = pre[i])
{
res[pre[i]][i] -= mind;
res[i][pre[i]] += mind;
}
maxFlow += mind;
}
return maxFlow;
} int main()
{
//freopen("in.txt", "r", stdin); while (~scanf("%d%d", &m, &n))
{
memset(res, 0, sizeof(res));
int u, v, c;
for (int i = 0; i < m; i++)
{
scanf("%d%d%d", &u, &v, &c);
res[u][v] += c;
} printf("%d\n", EK(1, n));
} return 0;
}
ACM/ICPC 之 网络流入门-EK算法(参考模板)(POJ1273)的更多相关文章
- ACM/ICPC 之 电力网络-EK算法(POJ1459)
		
按照电站发电(从源点到电站),消费者消费(从消费者到汇点)的想法构建网络,以下是EK解法 //网络流EK算法 //Time:922Ms memory:224K #include<iostream ...
 - ACM/ICPC 之 网络流入门-Ford Fulkerson与SAP算法(POJ1149-POJ1273)
		
第一题:按顾客访问猪圈的顺序依次构图(顾客为结点),汇点->第一个顾客->第二个顾客->...->汇点 //第一道网络流 //Ford-Fulkerson //Time:47M ...
 - 网络流入门——EK算法
		
转载:https://www.cnblogs.com/ZJUT-jiangnan/p/3632525.html 网络流的相关定义: 源点:有n个点,有m条有向边,有一个点很特殊,只出不进,叫做源点. ...
 - 【网络流】EK算法及其优化
		
今天上午我仿佛知道了什么叫做网络流,这里推荐一篇博客,大家入门网络流的可以看一下这篇博客,保证一看就懂! 博客链接: 网络流入门 这里有一篇经过我改过的EK带注释代码(博客里也有一样的,只是加了一些注 ...
 - HDU1532 网络流最大流【EK算法】(模板题)
		
<题目链接> 题目大意: 一个农夫他家的农田每次下雨都会被淹,所以这个农夫就修建了排水系统,还聪明的给每个排水管道设置了最大流量:首先输入两个数n,m ;n为排水管道的数量,m为节点的数量 ...
 - ACM/ICPC 之 网络流-拆点构图(POJ2391)
		
需要直接到达,因此源点经过三条边后必须要达到汇点,但为了保证网络流的正确性(路径可反悔),因此不可限制层次网络的最高层次为3,最好的方法既是让所有点拆分成两个点,一个点从汇点进入,一个点通向汇点,任意 ...
 - ACM/ICPC 之 计算几何入门-叉积-to left test(POJ2318-POJ2398)
		
POJ2318 本题需要运用to left test不断判断点处于哪个分区,并统计分区的点个数(保证点不在边界和界外),用来做叉积入门题很合适 //计算几何-叉积入门题 //Time:157Ms Me ...
 - ACM/ICPC 之 机器调度-匈牙利算法解最小点覆盖集(DFS)(POJ1325)
		
//匈牙利算法-DFS //求最小点覆盖集 == 求最大匹配 //Time:0Ms Memory:208K #include<iostream> #include<cstring&g ...
 - 网络流(EK算法)
		
poj1273 #include <iostream> #include <cstdio> #include <cstring> #include <queu ...
 
随机推荐
- 深入理解Java:类加载机制及反射
			
说明:本文乃学习整理参考而来. 一.Java类加载机制 1.概述 Class文件由类装载器装载后,在JVM中将形成一份描述Class结构的元信息对象,通过该元信息对象可以获知Class的结构信息:如构 ...
 - Windows phone应用开发[20]-禁止Pivot手势
			
相比Ios 和Android. Windows Phone 控件库中多了两个比较特殊的空间Pivot 枢轴和Panamera 全景视图控件.在基于枢轴控件Pivot中我们经常会碰到一些比较特殊应用场景 ...
 - 微信小程序 关于底部导航设置
			
在app.json 中添加 "tabBar": { "color":"#ffffff", "borderStyle":& ...
 - mac下 tomcat8+jdk1.8+servlet+Spring环境搭建中的问题
			
1,jdk1.8里面自带了servlet-api.jar tomcat里面也有这个,会导致冲突发生.出现这个问题会在控制台输出一大堆警告和错误,我一个一个去查(有的错误是表象不是核心)最后在stack ...
 - zookeeper系列之通信模型(转)
			
本文的主题就是讲解Zookeeper通信模型,本节将通过一个概要图来说明Zookeeper的通信模型. Zookeeper的通信架构 在Zookeeper整个系统中,有3中角色的服务,client.F ...
 - Java基础-一个java文件多个类的问题
			
一个.java文件当然可以包括多个类.但这些类有一个特殊的类与其它的不同,,这个类是带public 属性的类.一个.java类文件中仅有一个public属性的类.而且这个类与文件名相同.
 - 移动端webUI框架(HTML5手机框架)
			
淘宝SUI Mobile框架 官网地址:http://m.sui.taobao.org/ SUI Mobile 是一套基于 Framework7 开发的UI库.它非常轻量.精美,只需要引入我们的CDN ...
 - a版本冲刺第八天
			
队名:Aruba 队员: 黄辉昌 李陈辉 林炳锋 鄢继仁 张秀锋 章 鼎 学号 昨天完成的任务 今天做的任务 明天要做的任务 困难点 体会 408 继续学习第一行代码至第四章,阅读队友代码 着手 ...
 - 什么是Javascript Hoisting?
			
Javascript是一门容易遭人误解的语言,但是它的强大毋庸置疑.个人觉得,要想深入理解Javascript语言,首先必须对其基本的概念(例如:Scope,Closure,Hoisting等)要真正 ...
 - RabbitMQ简介
			
AMQP简介 在了解RabbitMQ之前,首先要了解AMQP协议.AMQP,即Advanced Message Queuing Protocol,高级消息队列协议,是应用层协议的一个开放标准,为面向消 ...