zoukankan      html  css  js  c++  java
  • ZKW费用流修正

     1 #include<iostream>
     2 #include<cstdio>
     3 #include<cmath>
     4 #include<algorithm>
     5 #include<stack>
     6 #include<queue>
     7 #include<cstring>
     8 #define PAU putchar(' ')
     9 #define ENT putchar('
    ')
    10 #define MSE(a,b) memset(a,b,sizeof(a))
    11 #define REN(x) for(ted*e=fch[x];e;e=e->nxt)
    12 #define TIL(x) for(int i=1;i<=x;i++)
    13 using namespace std;
    14 const int maxn=2000+10,maxm=20000+10,inf=1e9;
    15 struct zkw{
    16     struct ted{int x,y,w,c;ted*nxt,*re;}adj[maxm],*fch[maxn],*ms;
    17     int n,S,T,d[maxn],cost,ans;bool inq[maxn],vis[maxn];
    18     void init(int n){this->n=n;ms=adj;MSE(vis,false);MSE(inq,false);return;}
    19     void add(int x,int y,int w,int c){
    20         *ms=(ted){x,y,w,c,fch[x],ms+1};fch[x]=ms++;
    21         *ms=(ted){y,x,0,-c,fch[y],ms-1};fch[y]=ms++;
    22         return;
    23     }
    24     bool bfs(){
    25         TIL(n)d[i]=inf;queue<int>Q;Q.push(T);d[T]=0;
    26         while(!Q.empty()){
    27             int x=Q.front();Q.pop();inq[x]=false;REN(x){
    28                 int v=e->y;if(e->re->w&&d[v]>d[x]+e->re->c){
    29                     d[v]=d[x]+e->re->c;if(!inq[v])inq[v]=true,Q.push(v);
    30                 }
    31             }
    32         }for(ted*e=adj;e!=ms;e++)e->c+=d[e->y]-d[e->x];cost+=d[S];return d[S]!=inf;
    33     }
    34     int dfs(int x,int aug){
    35         if(x==T||!aug)return(ans+=aug*cost,aug);int flow=0,k;vis[x]=true;REN(x){
    36             int v=e->y;if(e->w&&!e->c&&!vis[v]&&(k=dfs(v,min(aug,e->w)))){
    37                 e->w-=k;e->re->w+=k;flow+=k;aug-=k;if(!aug)break;
    38             }
    39         }return flow;
    40     }
    41     int mcmf(int S,int T){
    42         this->S=S;this->T=T;while(bfs())do MSE(vis,false);while(dfs(S,inf));return ans;
    43     }
    44 }sol;
    45 inline int read(){
    46     int x=0,sig=1;char ch=getchar();
    47     for(;!isdigit(ch);ch=getchar())if(ch=='-')sig=0;
    48     for(;isdigit(ch);ch=getchar())x=10*x+ch-'0';
    49     return sig?x:-x;
    50 }
    51 inline void write(int x){
    52     if(x==0){putchar('0');return;}if(x<0)putchar('-'),x=-x;
    53     int len=0,buf[15];while(x)buf[len++]=x%10,x/=10;
    54     for(int i=len-1;i>=0;i--)putchar(buf[i]+'0');return;
    55 }
    56 int n,m;
    57 int main(){
    58     n=read();m=read();sol.init(n);int x,y,w;
    59     TIL(m)x=read(),y=read(),w=read(),sol.add(x,y,w,read());write(sol.mcmf(1,n));
    60     return 0;
    61 }
  • 相关阅读:
    童年记忆
    展现、通讯、IO
    通电自动开机
    英雄每多屠狗辈,自古侠女出风尘(看黄金大劫案有感)
    反射整理学习<一>(转)
    在ASP.NET中跟踪和恢复大文件下载
    高内聚、低耦合
    你需要权限才能执行此操作
    WP7应用开发笔记(5) 通信设计
    一个简单的软件工程流程
  • 原文地址:https://www.cnblogs.com/chxer/p/4740581.html
Copyright © 2011-2022 走看看