网络流初步

Posted yanlifneg

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了网络流初步相关的知识,希望对你有一定的参考价值。

由于我比较懒

博客写的不够精致

所以

https://blog.csdn.net/txl199106/article/details/64441994

哈哈哈哈哈哈哈这个博客里面的比喻能笑死哈哈哈哈哈哈

首先是一般的最大流算法 

/*
一般增广路算法(EdmondsKarp)
O m*m*n
codevs 1993
比较朴素的最大流算法
贪心的方法:找还可以放水的边或者流量大于零反边 
找到s-t的路径 如果没有 end 
否则 正向流量减去,反向加上相应的流量(类似回溯用)
每次Bfs找增广路 记录前驱
然后找路径的最小值 更新网络 
*/
#include<cstdio>
#include<cstring>
#include<iostream>
#include<queue>
#define maxn 210
using namespace std;
int n,m,G[maxn][maxn],vis[maxn],pre[maxn],ans;
queue<int>q;
bool Bfs(){
    while(!q.empty())q.pop();
    memset(vis,0,sizeof(vis));
    memset(pre,0,sizeof(pre));
    q.push(1);vis[1]=1;
    while(!q.empty()){
        int k=q.front();q.pop();
        for(int i=1;i<=n;i++)
            if(G[k][i]>0&&!vis[i]){
                vis[i]=1;pre[i]=k;q.push(i);
                if(i==n)return 1;
            }
    }
    return 0;
}
int main(){
    scanf("%d%d",&m,&n);
    int u,v,t;
    memset(G,0,sizeof(G));
    for(int i=1;i<=m;i++){
        scanf("%d%d%d",&u,&v,&t);
        G[u][v]+=t;
    }
    while(Bfs()){
        int pos=n,mt=2e9;
        while(pre[pos]){
            mt=min(mt,G[pre[pos]][pos]);
            pos=pre[pos];
        }
        pos=n;ans+=mt;
        while(pos){
            G[pre[pos]][pos]-=mt;
            G[pos][pre[pos]]+=mt;
            pos=pre[pos];
        }
    }
    printf("%d
",ans);
    return 0; 
}

 

以上是关于网络流初步的主要内容,如果未能解决你的问题,请参考以下文章

网络流初步

网络(最大)流初步+二分图初步 (浅谈EK,Dinic, Hungarian method:]

网络流初步详解

网络流初步

网络流初步

初等网络流初步