[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 ...
随机推荐
- Atlantis(POJ1151+线段树+扫描线)
题目链接:http://poj.org/problem?id=1151 题目: 题意:求所有矩形的面积,重合部分只算一次. 思路:扫描线入门题,推荐几篇学扫描线的博客: 1.http://www.cn ...
- 换行符 \r \n \r\n 在不同系统下的区别
'\r'是回车,前者使光标到行首,(carriage return)'\n'是换行,后者使光标下移一格,(line feed)\r 是回车,return\n 是换行,newline对于换行这个动作,u ...
- 从零开始PHP攻略(001)——Bob的汽车零部件商店
1.创建订单表单 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> < ...
- 宿主机mount虚拟机镜像文件
转载 mount挂载虚拟机镜像文件 使用mount挂载ubuntu虚拟机所在的img文件的时候,执行: “sudo mount -o loop xxx.img /mnt/xxx”, 系统提示: “mo ...
- 网络设备之分配net_device结构
注册网络设备时,会调用pci_driver->probe函数,以e100为例,最终会调用alloc_netdev_mqs来分配内存,并且在分配内存后调用setup函数(以太网为ether_set ...
- FreeRADIUS + MySQL 安装配置笔记
FreeRADIUS + MySQL 安装配置笔记 https://www.2cto.com/net/201110/106597.html
- 3D Studio Max [www]
https://github.com/RealityFactory/Exporters https://github.com/code-google-com/3ds-max-dev https://g ...
- codevs 1038 一元三次方程求解 NOIP2001提高组
题目链接:http://codevs.cn/problem/1038/ 题解: 嗯,exm?才知道二分隶属搜索专题…… 对-100到100枚举,按照题目中的提示,当当fi*fi+1<0时,二分深 ...
- C 实现有追求的线程池 后续
引言 -_- 还是老套路开局 很久以前写过一个有追求的线程池 -> C 实现有追求的线程池 探究 讲述的是一种思路, 并且实现了. 可以一用. 最近在详细搞simplec 框架. 准备发布个正式 ...
- [hadoop][基本原理]zookeeper场景使用
代码:https://github.com/xufeng79x/ZkClientTest 1. 简介 zookeeper的特性决定他适用到某些场景非常合适,比如典型的应用场景: 1.集群管理(Grou ...