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() );
    }
}


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

hdu 1532 Drainage Ditches (最大流—EK算法)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1532 Drainage Ditches Time Limit: 2000/10...

hdu1532 Drainage Ditches--最大流ek

原题链接: http://acm.hdu.edu.cn/showproblem.php?pid=1532 题意: n条路,m个点,每条边一个流速,求最大流速,1是源点,m是汇点。 依旧模...
  • LaoJiu_
  • LaoJiu_
  • 2016年08月11日 12:55
  • 188

HDU1532 Drainage Ditches(最大流)

学了一下午网络流,AC了这道模板题 勉强算是自己敲的,debug时参照了下模板,模板参照kuangbin大神 邻接表+isap算法 #include #include #define...

HDU1532 Drainage Ditches (最大流)

Drainage Ditches Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)...
  • d_x_d
  • d_x_d
  • 2016年06月22日 12:44
  • 1657

hdu1532Drainage Ditches 最大流模板水题

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

Drainage Ditches hdu 1532 最大流模板+入门题目

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

hdu 1532 Drainage Ditches 网络最大流模板 EK + Dinic两种算法AC

Problem Description Every time it rains on Farmer John's fields, a pond forms over Bessie's favorite...

hdu1532 Drainage Ditches(最大流)

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

hdu 1532/poj 1273 Drainage Ditches(最大流模板)

Drainage Ditches Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 67890   Accepted...
  • acm_cxq
  • acm_cxq
  • 2016年05月31日 12:40
  • 174

hdu 1532 Drainage Ditches【最大流】

Drainage Ditches Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:hdu 1532 Drainage Ditches(最大流)
举报原因:
原因补充:

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