网络流dinic ek模板 poj1273
这里只是用来存放模板,几乎没有讲解,要看讲解网上应该很多吧……
ek
bfs不停寻找增广路到找不到为止,找到终点时用pre回溯,O(VE^2)
#include<cstdio>
#include<iostream>
#include<cstring>
#include<queue>
#include<algorithm>
using namespace std;
const int INF = 0x3f3f3f3f;
const int maxn = ;
int cap[][], pre[], n, m, a[];
int bfs(){
queue<int> q;
q.push();
memset(a,,sizeof(a));
a[] = INF;
while(!q.empty()){
int front = q.front();
q.pop();
for(int i = ;i<=m;i++){
if(!a[i] && cap[front][i]){
a[i] = min(a[front], cap[front][i]);
pre[i] = front;
q.push(i);
}
}
}
return a[m];
}
int ek(){
int ans = ;
while(bfs()){
ans += a[m];
for(int i = m;i!=;i = pre[i]){
cap[pre[i]][i] -= a[m];
cap[i][pre[i]] += a[m];
}
}
return ans;
}
int main(){
while(~scanf("%d%d",&n,&m)){
memset(cap,,sizeof(cap));
for(int i = ;i<=n;i++){
int u,v,w;
scanf("%d%d%d",&u,&v,&w);
cap[u][v] += w;
}
printf("%d\n",ek());
}
return ;
}
dinic
反复构造层次网络加找增广路,优势在于当某点的流入量较大时,可以一次完成多条增广路的累加,O(V^2E)
记得初始化lv,cnt=1
#include<cstdio>
#include<iostream>
#include<cstring>
#include<queue>
#include<algorithm>
using namespace std;
const int maxn = ;
const int INF = 0x3f3f3f3f;
struct EDGE{
int to, next, cap, flow;
EDGE(){}
EDGE(int a, int b, int c, int d){
to = a, next = b, cap = c, flow = d;;
}
}e[];
int head[], cnt, lv[],m ,n;
void add(int from, int to, int cap){
e[++cnt] = EDGE(to, head[from], cap, );
head[from] = cnt;
e[++cnt] = EDGE(from, head[to], , );
head[to] = cnt;
}
int bfs(){
queue<int> q;
q.push();
memset(lv,,sizeof(lv));
lv[] = ;
while(!q.empty()){
int front = q.front();
q.pop();
for(int i = head[front];i;i = e[i].next){
int to = e[i].to;
if(!lv[to] && e[i].cap-e[i].flow){
lv[to] = lv[front]+;
q.push(to);
}
}
}
return lv[m];
}
int dfs(int now, int a){
int flow = ,f;
if(now == m) return a;
for(int i = head[now];i;i = e[i].next){
int to = e[i].to;
if(lv[to] == lv[now]+ && (f = dfs(to,min(a,e[i].cap-e[i].flow)))){
e[i].flow += f;
e[i^].flow -= f;
flow += f;
a -= f;
if(!a) break;
}
}
return flow;
}
int dinic(){
int ans = ;
while(bfs()){
ans += dfs(,INF);
}
return ans;
}
int main(){
while(~scanf("%d%d",&n,&m)){
cnt = ;
memset(head,,sizeof(head));
for(int i = ;i<=n;i++){
int u,v,w;
scanf("%d%d%d",&u,&v,&w);
add(u,v,w);
}
printf("%d\n",dinic());
}
return ;
}
网络流dinic ek模板 poj1273的更多相关文章
- 网络流Dinic算法模板 POJ1273
这就是以后我的板子啦~~~ #include <queue> #include <cstdio> #include <cstring> #include <a ...
- POJ 1273 Drainage Ditches(网络流dinic算法模板)
POJ 1273给出M条边,N个点,求源点1到汇点N的最大流量. 本文主要就是附上dinic的模板,供以后参考. #include <iostream> #include <stdi ...
- Drainage Ditches(POJ1273+网络流+Dinic+EK)
题目链接:poj.org/problem?id=1273 题目: 题意:求最大流. 思路:测板子题,分别用Dinic和EK实现(我的板子跑得时间均为0ms). Dinic代码实现如下: #includ ...
- POJ 3281 [网络流dinic算法模板]
题意: 农场主有f种食物,d种饮料,n头牛. 接下来的n行每行第一个数代表第i头牛喜欢吃的食物数量,和第i头牛喜欢喝的饮料数目. 接下来分别是喜欢的食物和饮料的编号. 求解:农场主最多能保证几头牛同时 ...
- HDU1532_Drainage Ditches(网络流/EK模板/Dinic模板(邻接矩阵/前向星))
Drainage Ditches Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- 网络流小记(EK&dinic&当前弧优化&费用流)
欢 迎 来 到 网 络 瘤 的 世 界 什么是网络流? 现在我们有一座水库,周围有n个村庄,每个村庄都需要水,所以会修水管(每个水管都有一定的容量,流过的水量不能超过容量).最终水一定会流向唯一一个废 ...
- POJ 1273 Drainage Ditches (网络流Dinic模板)
Description Every time it rains on Farmer John's fields, a pond forms over Bessie's favorite clover ...
- HDU1532最大流 Edmonds-Karp,Dinic算法 模板
Drainage Ditches Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) To ...
- POJ 1815 - Friendship - [拆点最大流求最小点割集][暴力枚举求升序割点] - [Dinic算法模板 - 邻接矩阵型]
妖怪题目,做到现在:2017/8/19 - 1:41…… 不过想想还是值得的,至少邻接矩阵型的Dinic算法模板get√ 题目链接:http://poj.org/problem?id=1815 Tim ...
随机推荐
- (1) Java实现JDBC连接及事务的方式
许多数据库的auto-commit默认是ON的,比如MySQL,PostgresSQL等.当然也有默认是OFF的,比如Oracle(Oracle里面执行DML语句是需要手动commit的). 这里我们 ...
- JEECG新建用户不用系统用户表的实现
首先新增组织机构 和 角色: -- 新增 组织机构 INSERT INTO `t_s_depart` VALUES ('dept001', '你所在的机构', '你所在的机构的描述', null, ' ...
- 报错: Domain=NSCocoaErrorDomain Code=3000 "未找到应用程序的“aps-environment”的权利字符串"
Code=3000 "未找到应用程序的“aps-environment”的权利字符串" 解决办法 push,即远程通知,教材的资料较少,想实践的话,只能每年花99美元买苹果开发者帐 ...
- php验证码实例
验证码实例如下看不懂的先看gd库的那一篇,session不懂的看from提交的数据都哪里了那一篇,欢迎关注 index.php <!DOCTYPE html> <html lang= ...
- 使用expect实现自动交互,shell命令行自动输入,脚本自动化,变量引用,expect spawn执行带引号命令,expect 变量为空,不生效,不能匹配通配符*,函数,数组
背景 有需求,在允许命令或者脚本跳出交互行,需要进行内容输入,但需要人手动输入,不是很方便,此时可以通过expect来实现自动互动交互. expect是一个自动交互功能的工具,可以满足代替我们实际工作 ...
- Andrew Ng机器学习课程17(2)
Andrew Ng机器学习课程17(2) 声明:引用请注明出处http://blog.csdn.net/lg1259156776/ 说明:主要介绍了利用value iteration和policy i ...
- VS2017.常量中有换行符
1.VS中加入 “/utf-8” Qt中 也是加入“/utf-8”,加的地方注意下:在 pro文件中 ,这个位置加入: win32-msvc*:QMAKE_CXXFLAGS += /wd"4 ...
- jira邮箱配置
系统-邮件-外发邮件
- Linux程序Segmentation fault (core dumped)
1 问题原因 Segmentation fault (core dumped)多为内存不当操作造成.空指针.野指针的读写操作,数组越界访问,破坏常量等.对每个指针声明后进行初始化为NULL是避免这个问 ...
- tp3.2判断修改成功
save方法的返回值是影响的记录数,如果返回false则表示更新出错,因此一定要用恒等来判断是否更新失败. 一开始用这种判断, if (!$edit_flag && $edit_fla ...