zoukankan      html  css  js  c++  java
  • NYOJ 323 Drainage Ditches 网络流 FF 练手

    Drainage Ditches

    时间限制:1000 ms  |  内存限制:65535 KB
    难度:4
    描述
    Every time it rains on Farmer John's fields, a pond forms over Bessie's favorite clover patch. This means that the clover is covered by water for awhile and takes quite a long time to regrow. Thus, Farmer John has built a set of drainage ditches so that Bessie's clover patch is never covered in water. Instead, the water is drained to a nearby stream. Being an ace engineer, Farmer John has also installed regulators at the beginning of each ditch, so he can control at what rate water flows into that ditch. 
    Farmer John knows not only how many gallons of water each ditch can transport per minute but also the exact layout of the ditches, which feed out of the pond and into each other and stream in a potentially complex network. 
    Given all this information, determine the maximum rate at which water can be transported out of the pond and into the stream. For any given ditch, water flows in only one direction, but there might be a way that water can flow in a circle. 
    输入
    The input includes several cases. For each case, the first line contains two space-separated integers, N (0 <= N <= 200) and M (2 <= M <= 200). N is the number of ditches that Farmer John has dug. M is the number of intersections points for those ditches. Intersection 1 is the pond. Intersection point M is the stream. Each of the following N lines contains three integers, Si, Ei, and Ci. Si and Ei (1 <= Si, Ei <= M) designate the intersections between which this ditch flows. Water will flow through this ditch from Si to Ei. Ci (0 <= Ci <= 10,000,000) is the maximum rate at which water will flow through the ditch.
    输出
    For each case, output a single integer, the maximum rate at which water may emptied from the pond.
    样例输入
    5 4
    1 2 40
    1 4 20
    2 4 20
    2 3 30
    3 4 10
    样例输出
    50
    来源
    USACO 93
    上传者
    张洁烽

    FF算法,不看模板,一遍AC(练手)同poj

    代码:

    #include<iostream>
    #include<string>
    #include<algorithm>
    #include<vector>
    #include<map>
    #include<queue>
    #include<cstdio>
    #include<cstring>
    #include<cmath>
    using namespace std;
    const int INF=0x3f3f3f3f;
    const int maxn=1e3+5;
    int capacity[maxn][maxn],flow[maxn][maxn];
    int v;
    int networkflow(int source, int sink) {
        int totalflow=0;
        memset(flow,0,sizeof(flow));
        while(true) {
            queue<int> q;
            vector<int> parent(maxn,-1);
            parent[source]=source;
            q.push(source);
            while(!q.empty()) {
                int here=q.front();q.pop();
                for(int there=0;there<v;there++) {
                    if(capacity[here][there]-flow[here][there]>0&&parent[there]==-1) {
                        parent[there]=here;
                        q.push(there);
                    }
                }
            }
            if(parent[sink]==-1) break;
            int amount=INF;
            for(int p=sink;p!=source;p=parent[p]) {
                amount=min(amount,capacity[parent[p]][p]-flow[parent[p]][p]);
            }
            for(int p=sink;p!=source;p=parent[p]) {
                flow[parent[p]][p]+=amount;
                flow[p][parent[p]]-=amount;
            }
            totalflow+=amount;
        }
        return totalflow;
    }
    int main() {
        int n,m;
        while(~scanf("%d%d",&m,&n)) {
            v=n;
            memset(capacity,0,sizeof(capacity));
            for(int i=0;i<m;++i) {
                int x,y,c;
                scanf("%d%d%d",&x,&y,&c);
                capacity[x-1][y-1]+=c;
            }
            printf("%d
    ",networkflow(0,n-1));
        }
        return 0;
    }
    


  • 相关阅读:
    让Div居中的方法
    创建对象的几种方式
    [Gport]2014移动互联网趋势——100名CEO的一句话解读
    专访腾讯云陈磊:微信云助力企业转型把握O2O时代价值
    Head First Python 学习笔记(第二章:分享你的代码)
    Head First Python 学习笔记(第一章:使用IDLE来帮助学习Python)
    《写给大家看的设计书》学习笔记
    用TreeView以递归显示选择磁盘上文件夹中全部文件夹和文件
    WebBrowser实现:自动填充网页上的用户名和密码并点击登录按钮
    C#调用免费天气预报WebService
  • 原文地址:https://www.cnblogs.com/lemonbiscuit/p/7775980.html
Copyright © 2011-2022 走看看