zoukankan      html  css  js  c++  java
  • Power Network POJ

    http://poj.org/problem?id=1459

    嗯,网络流模板...多源点多汇点的图,超级汇点连发电厂,用户连接超级汇点

    Status Accepted
    Time 391ms
    Memory 1588kB
    Length 2166
    Lang G++
    Submitted
    Shared
    RemoteRunId 18625420












    #include <iostream> #include <string.h> #include <cmath> #define ll long long #define IO ios::sync_with_stdio(false);cin.tie(0);cout.tie(0) #define pp pair<int,int> #define rep(ii,a,b) for(int ii=a;ii<=b;ii++) #define per(ii,a,b) for(int ii=a;ii>=b;ii--) #define show(x) cout<<#x<<"="<<x<<endl #define show2(x,y) cout<<#x<<"="<<x<<" "<<#y<<"="<<y<<endl #define show3(x,y,z) cout<<#x<<"="<<x<<" "<<#y<<"="<<y<<" "<<#z<<"="<<z<<endl #define showa(a,b) cout<<#a<<'['<<b<<"]="<<b[a]<<endl using namespace std; const int maxn=1e5+10; const int maxm=1e6+10; const ll INF=0x3f3f3f3f3f; int casn,n,np,nc,m,k; struct node {int to;ll cap;int next;}e[maxm]; int ss,tt,head[maxn],nume,dis[maxn],q[maxn]; inline void addx(int a,int b,ll c){ e[++nume]=(node){b,c,head[a]}; head[a]=nume; } inline void add(int a,int b,ll c){ addx(a,b,c);addx(b,a,0); } bool bfs(int s=ss,int t=tt){ int top=0,end=1; q[0]=s; for(int i=0;i<=t;i++) dis[i]=0; dis[s]=1; while(top!=end){ int now=q[top++];top%=maxn; for(int i=head[now];i;i=e[i].next){ int to=e[i].to; if(!dis[to]&&e[i].cap){ dis[to]=dis[now]+1; if(to==t)break; q[end++]=to;end%=maxn; } } } return dis[t]; } ll dfs(int now=ss,ll last=INF){ if(now==tt)return last; ll flow=0,det; for(int i=head[now];i;i=e[i].next){ int to=e[i].to; if(e[i].cap&&dis[to]==dis[now]+1){ det=dfs(to,min(last-flow,e[i].cap)); flow+=det; e[i].cap-=det; e[i^1].cap+=det; if(flow==last) return last; } } if(flow==0) dis[now]=-1; return flow; } int main(){ //#define test #ifdef test freopen("in.txt","r",stdin);freopen("out.txt","w",stdout); #endif int nc,np; IO; while(cin>>n>>np>>nc>>m){ char ch; memset(head,0,sizeof head); nume=1; ss=n+9,tt=n+10; rep(i,1,m) { int a,b,c; cin>>ch>>a>>ch>>b>>ch>>c; if(a==b) continue; add(a,b,c); } rep(i,1,np){ int a,b,c; cin>>ch>>a>>ch>>c; add(ss,a,c); } rep(i,1,nc){ int a,b,c; cin>>ch>>a>>ch>>c; add(a,tt,c); } int ans=0; while(bfs()){ // show(1); ans+=dfs(); // show(ans); } cout<<ans<<' '; } #ifdef test fclose(stdin);fclose(stdout);system("out.txt"); #endif return 0; }
  • 相关阅读:
    洛谷 P1653 猴子 解题报告
    洛谷 P2024 [NOI2001]食物链 解题报告
    洛谷 P1966 火柴排队 解题报告
    洛谷 P1311 选择客栈 解题报告
    洛谷 P3959 宝藏 解题报告
    二进制枚举子集技巧
    洛谷 P1841 [JSOI2007]重要的城市 解题报告
    洛谷 P2324 [SCOI2005]骑士精神 解题报告
    vector-size
    ubuntu 更换软件源
  • 原文地址:https://www.cnblogs.com/nervendnig/p/9076909.html
Copyright © 2011-2022 走看看