zoukankan      html  css  js  c++  java
  • UESTC 1143 数据传输 网络流 最大流 Dinic

    数据传输

    Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others)
     

    机房里面有m台电脑,n台网线,每条网线都每秒中最多传送的数据量,如今须要你计算从标号为1的电脑传送数据到编号为m的电脑,问一秒内

    最多传送多少数据?

    Input

    第1行: 两个用空格分开的整数N(0N200)和 M(2M200)N网线的数量,M是电脑的数量。

    第二行到第N+1行: 每行有三个整数,SiEi 和 Ci

    Si 和 Ei (1Si,EiM)  指明电脑编号。数据从 Si流向 Ei

    Ci(0Ci10,000,000)     是这条网线的最大容量。

    Output

    输出一个整数。即排水的最大流量。

    Sample input and output

    Sample Input Sample Output
    5 4
    1 2 40
    1 4 20
    2 4 20
    2 3 30
    3 4 10
    50
    

    Source

    2015 UESTC Training for Graph Theory
    The question is from here.

    My Solution

    最大流的Dinic算法  O(N^2 *M)   N vertices and M edges


    #include <iostream>
    #include <cstdio>
    #include <cstring>
    #include <queue>
    using namespace std;
    const int inf = 1000000000;
    const int maxn = 200, maxm = 200;         //the max number of vertices and edges
    
    struct Edge
    {
        int v, f, nxt;
    };
    
    int n, src, sink;
    int g[maxn+8];
    int nume;
    Edge e[maxm*2+8];
    
    void addedge(int u, int v, int c)
    {
        e[++nume].v = v;
        e[nume].f = c;
        e[nume].nxt = g[u];
        g[u] = nume;
        e[++nume].v = u;
        e[nume].f = 0;
        e[nume].nxt = g[v];
        g[v] = nume;
    }
    
    void init()
    {
        memset(g, 0, sizeof(g));
        nume = 1;
    }
    
    queue<int> que;
    bool vis[maxn+8];
    int dist[maxn+8];    //distance
    
    void bfs()
    {
        memset(dist, 0, sizeof(dist));
        while(!que.empty()) que.pop();
        vis[src] = true;
        que.push(src);
        while(!que.empty()){
            int u = que.front();
            que.pop();
            for(int i = g[u]; i; i = e[i].nxt) {
                if(e[i].f && !vis[e[i].v]) {
                    que.push(e[i].v);
                    dist[e[i].v] = dist[u] + 1;
                    vis[e[i].v] = true;
                }
            }
        }
    }
    
    int dfs(int u, int delta)
    {
        if(u == sink){
            return delta;
        }
        else{
            int ret = 0;
            for(int i = g[u]; delta && i; i = e[i].nxt) {
                if(e[i].f && dist[e[i].v] == dist[u] + 1) {
                    int dd = dfs(e[i].v, min(e[i].f, delta));
                    e[i].f -= dd;
                    e[i^1].f += dd;
                    delta -= dd;
                    ret += dd;
                }
            }
            return ret;
        }
    }
    
    int maxflow()
    {
        int ret = 0;
        while(true) {
            memset(vis, 0, sizeof(vis));
            bfs();
            if(!vis[sink]) return ret;
            ret += dfs(src, inf);
        }
    }
    
    int main()
    {
        int N, M, S, E, C;
        scanf("%d%d", &N, &M);
        src = 1;sink = M;
        while(N--){
            scanf("%d%d%d", &S, &E, &C);
            addedge(S, E, C);
        }
        printf("%d", maxflow());
        return 0;
    }

    Thank you!

  • 相关阅读:
    SDN第一次上机作业
    SDN第一次作业
    2017软件工程第二次作业
    Swift基础(一)
    iOS获取当前屏幕显示的viewcontroller
    Swift基础(二)
    属性和点语法
    Delphi 2008 和 C++Builder 将于8月25日发布
    为什么建议使用多重using
    .Net中Timers的学习备忘二
  • 原文地址:https://www.cnblogs.com/cxchanpin/p/7066295.html
Copyright © 2011-2022 走看看