#include<stdio.h>

#include<string.h>

#define N 300

#define inf 0x7fffffff

#include<queue>

using namespace std;

struct node {

  int u,v,w,next;

}bian[N*4];

int head[N],yong,d[N],s,t;

void addedge(int u,int v,int w) {

   bian[yong].u=u;

   bian[yong].v=v;

   bian[yong].w=w;

   bian[yong].next=head[u];

   head[u]=yong++;

}

int Min(int a,int b) {

return a>b?b:a;

}

int bfs() {

  int i,cur,v;

  queue<int>q;

  memset(d,0,sizeof(d));

  q.push(s);

  d[s]=1;

  while(!q.empty()) {

    cur=q.front();

    q.pop();

    for(i=head[cur];i!=-1;i=bian[i].next) {

        v=bian[i].v;

        if(bian[i].w&&!d[v]) {

            d[v]=d[cur]+1;

            if(v==t)

                return 1;

            q.push(v);

        }

    }

  }

  return 0;

}

int dfs(int u,int limit) {

   int cost=0,v,i,flow;

   if(u==t)

    return limit;

   for(i=head[u];i!=-1;i=bian[i].next) {

    v=bian[i].v;

    if(bian[i].w&&d[v]==d[u]+1) {

        flow=dfs(v,Min(limit-cost,bian[i].w));

        if(flow>0) {//

            bian[i].w-=flow;

            bian[i^1].w+=flow;

            cost+=flow;

            if(limit==cost)//如果已经搜到了满流就跳出

                break;

        }

        else

            d[v]=-1;//如果流量等于零,再遇到这个点就进行不下去了

    }

   }

   return cost;

}

int dinic() {

int sum=0;

while(bfs())//建层次图

    sum+=dfs(s,inf);//多次dfs搜索s-t增光路求可行流

    return sum;

}

int main(){

     int m,i,j,k,n;

     while(scanf("%d%d",&m,&n)!=EOF) {

        yong=0;

        memset(head,-1,sizeof(head));

        s=1;t=n;

        while(m--){

            scanf("%d%d%d",&i,&j,&k);

            addedge(i,j,k);//建边

            addedge(j,i,0);//建反向边

        }

        printf("%d\n",dinic());

     }

return 0;

}

poj 1273最大流dinic算法模板的更多相关文章

  1. POJ 3469.Dual Core CPU 最大流dinic算法模板

    Dual Core CPU Time Limit: 15000MS   Memory Limit: 131072K Total Submissions: 24830   Accepted: 10756 ...

  2. 求最大流dinic算法模板

    //最短增广路,Dinic算法 struct Edge { int from,to,cap,flow; };//弧度 void AddEdge(int from,int to,int cap) //增 ...

  3. 最大流Dinic算法模板(pascal)

    program rrr(input,output); const inf=; type pointer=^nodetype; nodetype=record t,c:longint; next,rev ...

  4. POJ 1273 Drainage Ditches(网络流dinic算法模板)

    POJ 1273给出M条边,N个点,求源点1到汇点N的最大流量. 本文主要就是附上dinic的模板,供以后参考. #include <iostream> #include <stdi ...

  5. POJ 1815 - Friendship - [拆点最大流求最小点割集][暴力枚举求升序割点] - [Dinic算法模板 - 邻接矩阵型]

    妖怪题目,做到现在:2017/8/19 - 1:41…… 不过想想还是值得的,至少邻接矩阵型的Dinic算法模板get√ 题目链接:http://poj.org/problem?id=1815 Tim ...

  6. HDU1532最大流 Edmonds-Karp,Dinic算法 模板

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

  7. hdu 2435 dinic算法模板+最小割性质

    #include<stdio.h> #include<queue> #include<string.h> using namespace std; #define ...

  8. 网络流之最大流Dinic算法模版

    /* 网络流之最大流Dinic算法模版 */ #include <cstring> #include <cstdio> #include <queue> using ...

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

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

随机推荐

  1. oracle 分页方法

    我分享两种: 1.用rownum select * from (select p.* , rownum rn  from t_premium p where rn<= page * 10) a ...

  2. MySQL 字符编码问题详细解释

    http://www.codesoil.net/tag/charset Character Set Problem in PHP + MySQL4.1+ 和许多人一样,我也是在转移blog时才发现这个 ...

  3. [Swift通天遁地]二、表格表单-(7)电子邮件Mail:实现单元格左右滑动调出功能按钮

    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...

  4. SpringCloud服务组合

    SpringCloud生态强调微服务,微服务也就意味着将各个功能独立的业务抽象出来,做成一个单独的服务供外部调用.但每个人对服务究竟要有多“微”的理解差异很大,导致微服务的粒度很难掌控,划分规则也不统 ...

  5. CF 436D 最小生成树

    设一个开头的虚节点,然后建稠密图,O(n^2).使用prim.O(n^2),保存方案,没什么好说的. #include <string.h> #include <stdio.h> ...

  6. C#图片辅助类,形成缩略图

    完善一下别人的方法,成自己好用的工具 using System.Drawing; using System.Drawing.Imaging; namespace GXNUQzzx.Tools.Util ...

  7. CF832B Petya and Exam

    思路: 模拟. 实现: #include <iostream> using namespace std; string a, b; ]; bool solve() { ) return f ...

  8. 原生js实现简单的焦点图效果

    用到一些封装好的运动函数,主要是定时器 效果为图片和图片的描述定时自动更换 <!DOCTYPE html> <html> <head> <meta chars ...

  9. android中TextView内容竖向显示

    项目中遇到需要textview内容竖着排的需求,如图所示: 网上那些“教程”并不能达到需要的效果,发现有一个属性可以支持这种效果,android:ems=“*”,这是属性表示一行只显示*个字符. 具体 ...

  10. Python常用的标准库及第三方库

    标准库Python拥有一个强大的标准库.Python语言的核心只包含数字.字符串.列表.字典.文件等常见类型和函数,而由Python标准库提供了系统管理.网络通信.文本处理.数据库接口.图形系统.XM ...