[HDU1532]Drainage Ditches
最大流模板题
今天补最大流,先写道模板题,顺便写点对它的理解
最大流问题就是给一个幽香有向图,每一条边有容量,问若从$s$点放水,最多会有多少水流到$t$
为了解决整个问题,第一步我们当然要找到一条路径让它达到满流的状态,这里直接xjbdfs即可

比如我们找到一条路径$1\to2\to3\to4$,流量为$2$
但是我们有可能需要“反悔”,比如不走$2\to3$而走$2\to4$
这时我们可以使用一些小技巧:添加反向边并更新正向边的容量

以后如果我们走了反向边就相当于是在“反悔”
我们把上述找一条路径的过程称为“寻找增广路”
为了避免处理环等奇怪的情况,我们在每次找增广路之前先bfs一次记录每条边边权为$1$的最短路(其实是把图分层),然后按照距离$dis$dfs,即在$u$时下一步只访问$dis[v]=dis[u]+1$的点$v$
每次bfs完要一直找增广路直到找不到为止,若bfs不能到达$t$则证明没有增广路(已经满流了)
代码挺短的2333
#include<stdio.h>
#include<string.h>
#define inf 1000000000
struct edge{
int to,nex,cap;
}e[410];
int h[210],dis[210],q[40010],tot,n;
void add(int a,int b,int c){
tot++;
e[tot].to=b;
e[tot].cap=c;
e[tot].nex=h[a];
h[a]=tot;
}
bool bfs(){
int head=1,tail=1,s,i;
q[1]=1;
memset(dis,-1,sizeof(dis));
dis[1]=0;
while(head<=tail){
s=q[head];
head++;
for(i=h[s];i;i=e[i].nex){
if(dis[e[i].to]==-1&&e[i].cap>0){
dis[e[i].to]=dis[s]+1;
tail++;
q[tail]=e[i].to;
}
}
}
return dis[n]>0;
}
int min(int a,int b){return a<b?a:b;}
int dfs(int x,int flow){
if(x==n)return flow;
int i,f;
for(i=h[x];i;i=e[i].nex){
if(e[i].cap>0&&dis[e[i].to]==dis[x]+1){
f=dfs(e[i].to,min(flow,e[i].cap));
if(f){
e[i].cap-=f;
e[i^1].cap+=f;
return f;
}
}
}
return 0;
}
int main(){
int m,i,a,b,c,ans,tmp;
while(~scanf("%d%d",&m,&n)){
tot=1;
memset(h,0,sizeof(h));
for(i=1;i<=m;i++){
scanf("%d%d%d",&a,&b,&c);
add(a,b,c);
add(b,a,0);
}
ans=0;
while(bfs()){
while(tmp=dfs(1,inf))ans+=tmp;
}
printf("%d\n",ans);
}
}
[HDU1532]Drainage Ditches的更多相关文章
- HDU1532 Drainage Ditches 网络流EK算法
Drainage Ditches Problem Description Every time it rains on Farmer John's fields, a pond forms over ...
- hdu-----(1532)Drainage Ditches(最大流问题)
Drainage Ditches Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- HDU1532 Drainage Ditches 【最大流量】
Drainage Ditches Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- HDU1532 Drainage Ditches SAP+链式前向星
Drainage Ditches Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- POJ1273&&Hdu1532 Drainage Ditches(最大流dinic) 2017-02-11 16:28 54人阅读 评论(0) 收藏
Drainage Ditches Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- HDU-1532 Drainage Ditches,人生第一道网络流!
Drainage Ditches 自己拉的专题里面没有这题,网上找博客学习网络流的时候看到闯亮学长的博客然后看到这个网络流入门题!随手一敲WA了几发看讨论区才发现坑点! 本题采用的是Edmonds-K ...
- HDU1532 Drainage Ditches —— 最大流(sap算法)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1532 Drainage Ditches Time Limit: 2000/1000 MS (Java/ ...
- HDU-1532 Drainage Ditches (最大流,EK算法模板)
题目大意:最大流的模板题...源点是0,汇点是n-1. 代码如下: # include<iostream> # include<cstdio> # include<cma ...
- POJ 1273 Drainage Ditches题解——S.B.S.
Drainage Ditches Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 67823 Accepted: 2620 ...
随机推荐
- [IOS]Xcode各版本官方下载及百度云盘下载, Mac和IOS及Xcode版本历史
官方下载, 用开发者账户登录,建议用Safari浏览器下载. 官方下载地址: https://developer.apple.com/xcode/downloads/ 百度云盘下载地址 http:// ...
- for in、each; for 、forEach、map
1.jQuery.each(object, [callback]) 用于例遍任何对象.回调函数拥有两个参数:第一个为对象的成员或数组的索引,第二个为对应变量或内容.如果需要退出 each 循环可使回调 ...
- ie8下input文字偏上select文字偏下
1.ie8下input文字偏上 正常情况下input的显示情况如下 当设置input的高度时,就会出现文字不垂直居中偏上的情况,如图 解决方案 强input的行高line-height与其高度设置一致 ...
- pandas中DataFrame使用
切片选择 #显示第一行数据print(df.head(1)) #显示倒数三行数据 print(df.tail(3)) loc df.loc[row_index,col_index] 注意loc是根 ...
- Perl6 Bailador框架(6):获取用户输入
use v6; use Bailador; get '/' => sub { ' <html> <head><title></title>< ...
- 一个基于时间注入的perl小脚本
use strict; use warnings; use LWP::Simple; my %table_and_leng; ;;$count++){ #print "Test Table: ...
- Deep Learning基础--线性解码器、卷积、池化
本文主要是学习下Linear Decoder已经在大图片中经常采用的技术convolution和pooling,分别参考网页http://deeplearning.stanford.edu/wiki/ ...
- 【bzoj1068】【SCOI2007】压缩
一道区间dp f[i][j][0/1]表示[i,j]区间是否加入M,并且之前一位有M的最小长度 可以理解为在第一位之前有一个M 那么就可以转移了. #include<bits/stdc++.h& ...
- VPS性能测试(2):内存大小、交换空间、高速缓存、实际使用内存
1.要想查看购买的VPS主机的内存信息,执行:cat /proc/meminfo,主要是看内存大小.交换空间.高速缓存 2.VPS主机实际使用内存大小.Linux管理内存的机制是这样的:无论物理内存有 ...
- yml格式
是什么? yml文件扩展名是YAML的缩写,YAML于2001年出现,是一种数据描述语言,和xml类似 为什么用它? 我们在做javaweb项目的时候最常见的就是.xml配置文件和properitie ...