zoukankan      html  css  js  c++  java
  • poj1459

    初涉网络流。改日再写一些概念性的介绍。

    ek算法可作为模板使用。

    #include <iostream>
    #include <queue>

    using namespace std;

    #define MAXN 105
    #define inf 1 << 20

    bool used[MAXN];
    int pre[MAXN];
    int map[MAXN][MAXN];
    int vertices, power_stations, consumers, edges;

    int EK()
    {
        int i, res = 0, now, min;
        queue<int>q;
        while (1)
        {
            memset(pre, -1, sizeof(pre));
            memset(used, 0, sizeof(used));
            while (!q.empty())
                q.pop();
            q.push(0);
            used[0] = true;
            while (!q.empty())
            {
                now = q.front();
                q.pop();
                if (now == vertices + 1)
                    break;
                for (i = 0; i <= vertices + 1; i++)
                {
                    if (!used[i] && map[now][i]>0)
                    {
                        pre[i] = now;
                        used[i] = true;
                        q.push(i);
                    }
                }
            }
            if (!used[vertices + 1])
                break;
            min = inf;
            for (i = vertices + 1; i != 0; i = pre[i])
            if (map[pre[i]][i]<min)
                min = map[pre[i]][i];
            res = res + min;
            for (i = vertices + 1; i != 0; i = pre[i])
            {
                map[pre[i]][i] = map[pre[i]][i] - min;
                map[i][pre[i]] = map[i][pre[i]] + min;
            }
        }
        return res;
    }

    int main()
    {

        while (cin >> vertices >> power_stations >> consumers >> edges)
        {
            memset(map, 0, sizeof(map));
            for (int i = 0; i < edges; i++)
            {
                char waste;
                int from, to, capacity;
                cin >> waste >> from >> waste >> to >> waste >> capacity;
                map[from+1][to+1] = capacity;
            }

            int super_s, super_t;
            super_s = 0, super_t = vertices + 1;
            //vertices += 2;

            for (int i = 0; i < power_stations; i++)
            {
                char waste;
                int to, capacity;
                cin >> waste >> to >> waste >> capacity;
                map[super_s][to+1] = capacity;
            }

            for (int i = 0; i < consumers; i++)
            {
                char waste;
                int from, capacity;
                cin >> waste >> from >> waste >> capacity;
                map[from+1][super_t] = capacity;
            }
            cout << EK() << endl;
        }
        return 0;
    }



  • 相关阅读:
    汤姆大叔 深入理解JavaScript系列(20):《你真懂JavaScript吗?》答案详解 后六道题答案
    canvas绘制自定义的曲线,以椭圆为例,通俗易懂,童叟无欺
    nodejs 平台的 webscoket 的实现
    javascript 控制台输出 图片 console.log 真强大 真佩服你们的创造力
    ichartjs 使用BUG,assign_scale:true 解决
    timequest静态时序分析学习笔记之工具使用
    timequest静态时序分析学习笔记之命令约束
    timequest静态时序分析学习笔记之基本概念
    浅谈“意识”的物质性
    构建异步处理网络服务器
  • 原文地址:https://www.cnblogs.com/fuhaots2009/p/3429325.html
Copyright © 2011-2022 走看看