1. #include<bits/stdc++.h>
  2. using namespace std;
  3. #define maxn 1005
  4. #define ll long long
  5.  
  6. const ll inf = 0x3f3f3f3f3f3f3f3f;
  7.  
  8. struct Edge{ll to,nxt,w;}e[maxn<<];
  9. int head[maxn],tot,n,m;
  10. void init(){
  11. memset(e,,sizeof e);
  12. memset(head,-,sizeof head);
  13. tot=;
  14. }
  15. void add(ll u,ll v,ll w){
  16. e[tot].to=v;e[tot].nxt=head[u];e[tot].w=w;head[u]=tot++;
  17. }
  18.  
  19. int d[maxn];
  20. bool bfs(){//在残量网络上构造分层图
  21. memset(d,,sizeof d);
  22.  
  23. queue<int>q;
  24. while(q.size())q.pop();
  25. q.push();d[]=;
  26.  
  27. while(q.size()){
  28. int x=q.front();q.pop();
  29. for(int i=head[x];i!=-;i=e[i].nxt){
  30. int y=e[i].to;
  31. if(d[y] || e[i].w==)continue;
  32. q.push(y);
  33. d[y]=d[x]+;
  34. if(y==n)return ;
  35. }
  36. }
  37. return ;
  38. }
  39. int dinic(int x,ll flow){
  40. if (x==n)return flow;
  41. ll rest=flow;
  42. for(int i=head[x];i!=- && rest>;i=e[i].nxt){
  43. int y=e[i].to;
  44. if(e[i].w== || d[y]!=d[x]+)continue;
  45. ll k=dinic(y,min(rest,e[i].w));
  46. if(!k) d[y]=; //y点已经被增广完毕
  47. e[i].w-=k; e[i^].w+=k;
  48. rest-=k;
  49. }
  50. return flow-rest;
  51. }
  52.  
  53. int main(){
  54. while(cin>>m>>n){
  55. init();
  56. for(int i=;i<=m;i++){
  57. ll u,v,w;
  58. cin>>u>>v>>w;
  59. add(u,v,w);
  60. add(v,u,);
  61. }
  62. ll flow=,ans=;
  63. while(bfs())
  64. while(flow=dinic(,inf))
  65. ans+=flow;
  66. cout<<ans<<'\n';
  67. }
  68. }

最大流dicnic——hdu1532模板题的更多相关文章

  1. HDU-3549 最大流模板题

    1.HDU-3549   Flow Problem 2.链接:http://acm.hdu.edu.cn/showproblem.php?pid=3549 3.总结:模板题,参考了 http://ww ...

  2. POJ 1459 Power Network(网络最大流,dinic算法模板题)

    题意:给出n,np,nc,m,n为节点数,np为发电站数,nc为用电厂数,m为边的个数.      接下来给出m个数据(u,v)z,表示w(u,v)允许传输的最大电力为z:np个数据(u)z,表示发电 ...

  3. 【网络流#2】hdu 1533 - 最小费用最大流模板题

    最小费用最大流,即MCMF(Minimum Cost Maximum Flow)问题 嗯~第一次写费用流题... 这道就是费用流的模板题,找不到更裸的题了 建图:每个m(Man)作为源点,每个H(Ho ...

  4. 【网络流#1】hdu 3549 - 最大流模板题

    因为坑了无数次队友 要开始学习网络流了,先从基础的开始,嗯~ 这道题是最大流的模板题,用来测试模板好啦~ Edmonds_Karp模板 with 前向星 时间复杂度o(V*E^2) #include& ...

  5. 【最大流ISAP】洛谷P3376模板题

    题目描述 如题,给出一个网络图,以及其源点和汇点,求出其网络最大流. 输入输出格式 输入格式: 第一行包含四个正整数N.M.S.T,分别表示点的个数.有向边的个数.源点序号.汇点序号. 接下来M行每行 ...

  6. POJ 1273 - Drainage Ditches - [最大流模板题] - [EK算法模板][Dinic算法模板 - 邻接表型]

    题目链接:http://poj.org/problem?id=1273 Time Limit: 1000MS Memory Limit: 10000K Description Every time i ...

  7. 洛谷 P3128 [USACO15DEC]最大流Max Flow-树上差分(点权/点覆盖)(模板题)

    因为徐州现场赛的G是树上差分+组合数学,但是比赛的时候没有写出来(自闭),背锅. 会差分数组但是不会树上差分,然后就学了一下. 看了一些东西之后,对树上差分写一点个人的理解: 首先要知道在树上,两点之 ...

  8. hdu 3549 Flow Problem【最大流增广路入门模板题】

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=3549 Flow Problem Time Limit: 5000/5000 MS (Java/Others ...

  9. hdu 1532 Drainage Ditches(最大流模板题)

    Drainage Ditches Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

随机推荐

  1. 8u ftp 可以连接但是无法获取目录的解决办法:无法打开传输通道。原因:由于...

    来自: http://www.3566t.com/news/dlsn/1557906.html 状态:  正在取得目录列表... 命令:  CWD xinghun 响应:  250 OK. Curre ...

  2. wpf mvvm datagrid 中button绑定命令方法

    <DataGridTemplateColumn Header="设备状态" IsReadOnly="True" Width="150" ...

  3. mongo之$rename更新一个字段的名称(可批量)

    $rename操作逻辑执行$unset 老名称和新的名称,然后执行 $set新名称运行.因此,操作可能不保留文档中字段的顺序; 即重命名的字段可以在文档内移动. 1.重命名字段:一级字段 格式: db ...

  4. Pregel的计算过程

  5. leetcode-并查集

    - 题目:130 并查集: class Solution: def solve(self, board: List[List[str]]) -> None: """ ...

  6. HTML中的相对路径与绝对路径

    路径 实际工作中,通常新建一个文件夹专门用于存放图像文件,这时再插入图像,就需要采用“路径”的方式来指定图像文件的位置. 路径可以分为: 相对路径和绝对路径 相对路径 图像文件和HTML文件位于同一文 ...

  7. bzoj1061题解

    [解题思路] 设类型i的志愿者,即第Si天~第Ti天工作的志愿者,共招募xi个,于是有不等式组Σxj≥Ai(Sj≤i≤Tj). 这样,题目就变成了求一组满足一次不等式组的xi,使ΣCixi最小,即标准 ...

  8. 牛客多校第三次B——线段树维护线性基交

    写线性基交函数时调试了半天.. #include<bits/stdc++.h> using namespace std; #define ll long long #define maxn ...

  9. Codeforces768B-Code For 1-类似线段树-枚举+单点更新or区间更新

    目录 Catalog Solution: (有任何问题欢迎留言或私聊 && 欢迎交流讨论哦 Catalog Problem:Portal传送门  原题目描述在最下面.  每次把\(n\ ...

  10. oracle11g 导出表报EXP-00011:table不存在。

    oracle11g 导出表报EXP-00011:table不存在. oracle11g,在用exp命令备份数据库时,如果表中没有数据报EXP-00011错误,对应的表不存在.这导致对应的空表无法备份. ...