zoukankan      html  css  js  c++  java
  • 洛谷P3376【模板】网络最大流  Dinic模板

    之前的Dinic模板照着刘汝佳写的vector然后十分鬼畜跑得奇慢无比,虽然别人这样写也没慢多少但是自己的就是令人捉急。

    改成邻接表之后快了三倍,虽然还是比较慢但是自己比较满意了。虽然一开始ecnt从0开始WA了一发。。。

    之前的码风也十分鬼畜呀缩进只缩1、2格不懂自己怎么想的。。

    反正今天就安心划划水。

    #include<cstdio>
    #include<cstring>
    #include<iostream>
    #include<algorithm>
    #include<cmath>
    #include<queue>
    #include<vector>
    typedef long long LL;
    const int maxn=20050,maxm=200050,INF=0x7f7f7f7f;
    using namespace std;
    int n,m,s,t,u,v,w,ecnt=1,fir[maxn],dis[maxn],cur[maxn],ans;
    struct edge {
        int from,to,cap,flow,nxt;
        edge(){}
        edge(int from,int to,int cap,int flow,int nxt):from(from),to(to),cap(cap),flow(flow),nxt(nxt){}
    }e[maxm];
    void add(int u,int v,int w) {
        e[++ecnt]=edge(u,v,w,0,fir[u]);     
        e[++ecnt]=edge(v,u,0,0,fir[v]); 
        fir[u]=ecnt-1; fir[v]=ecnt;
    }
    void init() {
        scanf("%d%d%d%d",&n,&m,&s,&t);
        for(int i=1;i<=m;i++) {
            scanf("%d%d%d",&u,&v,&w);
            add(u,v,w);
        }
    }
    queue<int>que;
    int bfs(int s,int t) {
        memset(dis,0,sizeof(dis));
        dis[s]=1; 
        que.push(s);
        while(!que.empty()) {
            int x=que.front() ;que.pop();
            for(int i=fir[x];i;i=e[i].nxt) 
            if(!dis[e[i].to]&&e[i].flow<e[i].cap) {
                dis[e[i].to]=dis[x]+1;
                que.push(e[i].to); 
            }
        }
        return dis[t];
    }
    int dfs(int x,int a) {
        if(x==t||a==0) return a;
        int fl,f=0;
        for(int &i=cur[x];i;i=e[i].nxt) {
        if(dis[e[i].to]==dis[x]+1&&(fl=dfs(e[i].to,min(a,e[i].cap-e[i].flow)))){
            e[i].flow+=fl;
            e[i^1].flow-=fl;
            a-=fl;
            f+=fl;
            }
            if(a==0) break;
        }
        return f;
    }
    int Dinic(int s,int t) {
        int res=0;
        while(bfs(s,t)) {
            for(int i=1;i<=n;i++) cur[i]=fir[i];
            res+=dfs(s,INF);
        }
        return res;
    }
    void work() {
        ans=Dinic(s,t);
        printf("%d
    ",ans);
    }
    int main()
    {
        init();
        work();
        return 0;
    }
    View Code

     

  • 相关阅读:
    Java分享笔记:关于Java反射机制
    Java分享笔记:自定义枚举类 & 使用enum关键字定义枚举类
    Java分享笔记:RandomAccessFile流 & 在文件指定位置插入内容
    Spark-源码-SparkContext的初始化
    Spark-源码-Spark-StartAll Master Worler启动流程
    Spark-源码-Spark-Submit 任务提交
    Hadoop2学习路程-HDFS
    JavaSE 第二次学习随笔(五)
    JavaSE 第二次学习随笔(四)
    JavaSE 第二次学习随笔(三)
  • 原文地址:https://www.cnblogs.com/Achenchen/p/7534817.html
Copyright © 2011-2022 走看看