标签:search some tput purpose integer ase cst show cstring
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 2890 Accepted Submission(s): 1258
#include<iostream> #include<cstdio> #include<cstring> #include<algorithm> #define LL int #define MAXN 100000+15 using namespace std; LL n,m,tot,tim,top,sumcol,ans,bns,cap[MAXN]; LL to[MAXN],from[MAXN],net[MAXN],col[MAXN],val[MAXN]; LL dfn[MAXN],low[MAXN],vis[MAXN],stack[MAXN],visstack[MAXN]; inline void add(LL u,LL v,LL w){ to[++tot]=v;net[tot]=from[u];from[u]=tot;cap[tot]=w; } inline void tarjin(LL now){ low[now]=dfn[now]=++tim; stack[++top]=now; visstack[now]=1; vis[now]=1; for(LL i=from[now];i;i=net[i]) if(visstack[to[i]]) low[now]=min(low[now],dfn[to[i]]); else if(!vis[to[i]]){ tarjin(to[i]); low[now]=min(low[now],low[to[i]]); } if(dfn[now]==low[now]){ sumcol++; col[now]=sumcol; while(stack[top]!=now){ col[stack[top]]=sumcol; visstack[stack[top]]=0; top--; } visstack[now]=0; top--; } } int main(){ while(scanf("%d%d",&n,&m)!=EOF){ top=0;tot=0;sumcol=0;tim=0; ans=0;bns=0; memset(to,0,sizeof(to)); memset(low,0,sizeof(low)); memset(dfn,0,sizeof(dfn)); memset(vis,0,sizeof(vis)); memset(col,0,sizeof(col)); memset(net,0,sizeof(net)); memset(from,0,sizeof(from)); memset(val,0x3f,sizeof(val)); memset(stack,0,sizeof(stack)); memset(visstack,0,sizeof(visstack)); for(LL i=1;i<=m;i++){ LL a,b,c; scanf("%d%d%d",&a,&b,&c); add(a+1,b+1,c); } for(LL i=1;i<=n;i++) if(!vis[i]) tarjin(i); for(LL i=1;i<=n;i++) for(int j=from[i];j;j=net[j]) if(col[to[j]]!=col[i]) val[col[to[j]]]=min(val[col[to[j]]],cap[j]); long long ans=0; for(LL i=1;i<=sumcol;i++) if(val[i]!=1061109567) ans+=1ll*val[i]; printf("%lld\n",ans); } }
标签:search some tput purpose integer ase cst show cstring
原文地址:http://www.cnblogs.com/cangT-Tlan/p/7400747.html