题目背景

在农夫约翰的农场上,每逢下雨,贝茜最喜欢的三叶草地就积聚了一潭水。这意味着草地被水淹没了,并且小草要继续生长还要花相当长一段时间。因此,农夫约翰修建了一套排水系统来使贝茜的草地免除被大水淹没的烦恼(不用担心,雨水会流向附近的一条小溪)。作为一名一流的技师,农夫约翰已经在每条排水沟的一端安上了控制器,这样他可以控制流入排水沟的水流量。

题目描述

农夫约翰知道每一条排水沟每分钟可以流过的水量,和排水系统的准确布局(起点为水潭而终点为小溪的一张网)。需要注意的是,有些时候从一处到另一处不只有一条排水沟。

根据这些信息,计算从水潭排水到小溪的最大流量。对于给出的每条排水沟,雨水只能沿着一个方向流动,注意可能会出现雨水环形流动的情形。

输入格式

第1行: 两个用空格分开的整数N (0 <= N <= 200) 和 M (2 <= M <= 200)。N是农夫John已经挖好的排水沟的数量,M是排水沟交叉点的数量。交点1是水潭,交点M是小溪。

第二行到第N+1行: 每行有三个整数,Si, Ei, 和 Ci。Si 和 Ei (1 <= Si, Ei <= M) 指明排水沟两端的交点,雨水从Si 流向Ei。Ci (0 <= Ci <= 10,000,000)是这条排水沟的最大容量。

输出格式

输出一个整数,即排水的最大流量。


#include<queue>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
const int N=1e6+10,M=2*N,mod=1e9+7,inf=1<<30;
int nxt[M],head[N],go[M],edge[M],tot;
inline void add(int u,int v,int o){
nxt[++tot]=head[u];head[u]=tot;go[tot]=v;edge[tot]=o;
nxt[++tot]=head[v];head[v]=tot;go[tot]=u;edge[tot]=0;
}
int n,m,s,t,maxflow;
int d[N];
inline bool bfs(){
queue<int>q; memset(d,0,sizeof(d));
q.push(s); d[s]=1;
while(q.size()){
int u=q.front(); q.pop();
for(int i=head[u];i;i=nxt[i]){
int v=go[i];
if(!d[v]&&edge[i]){
d[v]=d[u]+1;
if(v==t)return 1;
q.push(v);
}
}
}
return 0;
}
inline int dinic(int u,int flow){
int rest=flow,k;
if(u==t)return flow;
for(int i=head[u];i;i=nxt[i]){
int v=go[i];
if(d[v]==d[u]+1&&edge[i]){
k=dinic(v,min(rest,edge[i]));
if(!k)d[v]=-1;
edge[i]-=k;
edge[i^1]+=k;
rest-=k;
}
}
return flow-rest;
}
signed main(){
cin>>n>>m; s=1, t=m;
for(int i=1,u,v,o;i<=n;i++){
scanf("%d%d%d",&u,&v,&o);
add(u,v,o);
}
int flow=0;
while(bfs())
while((flow=dinic(s,inf)))maxflow+=flow;
cout<<maxflow<<endl;
}

最新文章

  1. .NET LINQ标准查询运算符
  2. linux指定nologin用户执行命令
  3. FancyBox - 经典的 jQuery Lightbox 插件
  4. nodeType的12种类型
  5. sqlite3把字段为int32(用c++的time(nullptr)获取的)的秒数显示为年月日时分秒
  6. Windows 10触摸板手势
  7. STM32 对内部FLASH读写接口函数
  8. WP7应用版本升级的实现方法
  9. C# redis 分布式session存储
  10. ssh使用ajax异步通讯. json与对象转换的几个小问题
  11. hdu5976贪心乘法逆元
  12. ExtJS4 的dom
  13. struts2拦截器-自定义拦截器,放行某些方法(web.xml配置)
  14. Android 微信第三方登录
  15. Docker Machine 简介
  16. 【Core2.0帮助类】
  17. 第十三节,OPenCV学习(二)图像的简单几何变换
  18. (原)faster rcnn的tensorflow代码的理解
  19. 【Mac AndroidStudio】download gradle fail问题
  20. Java -- JDBC 学习--调用函数&amp;存储过程

热门文章

  1. 获取Ubuntu的Docker CE
  2. raw文件转mha文件
  3. VSCode JAVA环境配置使遇到的几个小问题
  4. 创建windows系统下的虚拟机
  5. Cauchy-Binet公式的证明 及 对Denton et al. (2019)的个人注(1)
  6. sqlite修改表、表字段等与sql server的不同之处
  7. linux内核崩溃之kdump机制
  8. 【笔记】vue和ssm开发接口联调跨域问题
  9. diff算法
  10. Salesforce学习之路(十二)Aura组件表达式