Cod sursa(job #608515)

Utilizator BlaugranasEnal Gemaledin Blaugranas Data 17 august 2011 00:17:21
Problema Cc Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.11 kb
#include<stdio.h>
#define E 100001
#define N 202
long e=0;
int k,i,j,n,v[N][N],c[N][N],f[N][N],w[E],u[N],g[N],p,q,t,l;
int main()
{freopen("cc.in","r",stdin);
freopen("cc.out","w",stdout);
scanf("%d",&n);
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
      {scanf("%d",&k);
      v[i][n+j+1]=k,v[n+j+1][i]=-k;
      c[i][n+j+1]=1;}
for(i=1;i<=n;i++)
      c[0][i]=c[i+n+1][n+1]=1,v[0][i]=v[i+n+1][n+1]=0;
while(1)      
       {for(i=1;i<=2*n+1;i++)
               u[i]=0,g[i]=E;
       g[0]=p=q=0,w[q++]=0;
       while(p<q)
               {t=w[p++];
               if(t&&t<=n)
                       {for(i=n+1;i<=2*n+1;i++)
                       if(f[t][i]<c[t][i]&&g[i]>g[t]+v[t][i])
                               w[q++]=i,u[i]=t,g[i]=g[t]+v[t][i];}
               else
                       for(i=1;i<=n+1;i++)
                       if(f[t][i]<c[t][i]&&g[i]>g[t]+v[t][i])
                               w[q++]=i,u[i]=t,g[i]=g[t]+v[t][i];}
       if(!u[n+1])
               break;
       for(l=n+1;l;l=u[l])
               f[u[l]][l]++,f[l][u[l]]--;
       e+=g[n+1];}
printf("%ld",e);
return 0;}