标签:
Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/65535 K (Java/Others)
Total Submission(s): 1812 Accepted Submission(s): 910
#include<iostream> #include<cstdio> #include<cstring> #include<string> #include<cmath> #include<cstdlib> #include<algorithm> #include<queue> #include<vector> #include<stack> using namespace std; #define INF 1<<30 int n,m,link[105],w[105][105],visx[105],visy[105],lx[105],ly[105],slack[105]; int dfs(int x) { visx[x]=1; for(int y=1;y<=n;y++) { if(visy[y]) continue; int t=lx[x]+ly[y]-w[x][y]; if(t==0) { visy[y]=1; if(link[y]==-1||dfs(link[y])) { link[y]=x; return 1; } } else if(slack[y]>t) slack[y]=t; } return 0; } int km() { memset(link,-1,sizeof(link)); memset(ly,0,sizeof(ly)); for(int i=1;i<=n;i++) { lx[i]=-INF; for(int j=1;j<=n;j++) lx[i]=max(lx[i],w[i][j]); } for(int x=1;x<=n;x++) { for(int i=1;i<=n;i++) slack[i]=INF; while(1) { memset(visx,0,sizeof(visx)); memset(visy,0,sizeof(visy)); if(dfs(x)) break; int d=INF; for(int i=1;i<=n;i++) { if(!visy[i]&&d>slack[i]) d=slack[i]; } for(int i=1;i<=n;i++) { if(visx[i]) lx[i]-=d; } for(int i=1;i<=n;i++) { if(visy[i]) ly[i]+=d; else slack[i]-=d; } } } int res=0; for(int i=1;i<=n;i++) res+=w[link[i]][i]; return res; } int main() { int u,v,p; while(scanf("%d%d",&n,&m)!=EOF) { bool flag=true; for(int i=1;i<=n;i++) for(int j=1;j<=n;j++) w[i][j]=-INF; for(int i=1;i<=m;i++) { scanf("%d%d%d",&u,&v,&p); if(-p>w[u][v]) w[u][v]=-p; } int ans=km(); for(int i=1;i<=n;i++) { if(link[i]==-1||w[link[i]][i]==-INF) { flag=false; break; } } if(!flag) printf("-1\n"); else printf("%d\n",-ans); } return 0; }
标签:
原文地址:http://www.cnblogs.com/a972290869/p/4350976.html