hdu 1532 Drainage Ditches(最大流)

原创 2015年07月10日 18:11:28

题目链接:

点击打开链接

题目大意:

给出一些渠道,每个渠道有一个走向和容量,问最终汇集到溪流中的水的总量

题目分析:

裸裸的网络流的最大流,模板题

代码如下:

#include <iostream>
#include <cstring>
#include <algorithm>
#include <cstdio>
#include <queue>
#define MAX 207
#define INF 0x3f3f3f3f

using namespace std;

int n,m;
int s[MAX][MAX];
int d[MAX];

bool bfs ( )
{
    queue<int> q;
    memset ( d , -1 , sizeof ( d ) );
    d[1] = 0;
    q.push ( 1 );
    while ( !q.empty() )
    {
        int v = q.front();
        q.pop();
        for ( int i = 1 ; i <= n ; i++ )
            if ( d[i] == -1 && s[v][i] )
            {
                d[i] = d[v]+1;
                q.push ( i );
            }
    }
    return d[n] != -1;
}

int dfs ( int v , int cur_flow )
{
    int dt = cur_flow;
    if ( v == n ) return cur_flow;
    for ( int i = 1 ; i <= n ; i++ )
        if ( s[v][i] > 0 && d[v]+1 == d[i] )
        {
            int flow = dfs ( i , min ( dt , s[v][i] ) );
            s[v][i] -= flow;
            s[i][v] += flow;
            dt -= flow;
        }
    return cur_flow - dt;
}

int dinic ( )
{
    int cur_flow, ans = 0;
    while ( bfs() )
    {
        while ( cur_flow = dfs ( 1 , INF ) )
            ans += cur_flow;
    }
    return ans;
}

int main ( )
{
    while ( ~scanf ( "%d%d" , &m , &n ) )
    {
        int u,v,c;
        memset ( s , 0 , sizeof ( s ) );
        while ( m-- )
        {
            scanf ( "%d%d%d" , &u , &v , &c );
            s[u][v] += c;
        }
        //cout << "YES" << endl;
        printf ( "%d\n" , dinic() );
    }
}


版权声明:本文为博主原创文章,未经博主允许不得转载。

hdoj 1532 Drainage Ditches 题解(最大流)

Drainage Ditches Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others...
  • y990041769
  • y990041769
  • 2014年03月27日 11:27
  • 5930

hdu1532Drainage Ditches 最大流模板水题

感觉这道题纯粹就是试模板的,给一个有向图,求其最大流 Dinic算法:#include #include #include #include using namespace std; #defin...
  • cq_pf
  • cq_pf
  • 2015年08月10日 16:37
  • 553

hdu 1532 Drainage Ditches (网络流两种方法)

hdu 1532 Drainage Ditches (网络流两种方法)
  • u012860063
  • u012860063
  • 2014年03月04日 17:54
  • 2001

hdu 1532 Drainage Ditches【最大流】

Drainage Ditches Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)...
  • mengxiang000000
  • mengxiang000000
  • 2016年03月31日 20:13
  • 315

hdu 1532 Drainage Ditches(最大流)

题目:         链接:点击打开链接 题意:         求最大流速。 思路:         Edmond_karp就行。 代码: #include #include #include...
  • u013147615
  • u013147615
  • 2014年06月30日 19:21
  • 328

HDU 1532 Drainage Ditches(最大流)

Drainage Ditches Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others...
  • u013555159
  • u013555159
  • 2016年08月19日 10:56
  • 110

HDU 1532 Drainage Ditches 最大流

Drainage Ditches Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)...
  • u012605629
  • u012605629
  • 2014年08月19日 17:16
  • 481

hdu 1532 Drainage Ditches (最大流)

最大流的第一道题,刚开始学这玩意儿,感觉好难啊!哎····· 希望慢慢地能够理解一点吧! #include #include #include using namespace std; #d...
  • u011518888
  • u011518888
  • 2013年08月06日 11:06
  • 555

HDU 1532 Drainage Ditches (最大流)

问题描述:Problem Description Every time it rains on Farmer John’s fields, a pond forms over Bessie’s fa...
  • sinat_34336698
  • sinat_34336698
  • 2016年10月18日 21:14
  • 73

hdu 1532 Drainage Ditches 最大流

题目 http://acm.hdu.edu.cn/showproblem.php?pid=1532 这是最大流的一个简单题哦   我是用Edmond-Karp来做的哦   思想是每次找出一条最短路,...
  • aibianchendewo
  • aibianchendewo
  • 2013年05月22日 19:09
  • 330
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:hdu 1532 Drainage Ditches(最大流)
举报原因:
原因补充:

(最多只允许输入30个字)