Pagini recente » Istoria paginii utilizator/dmgciubotaru | Statistici Smerica Valeriu (junkie) | Istoria paginii utilizator/lilpmario | Istoria paginii utilizator/vlad_cristian.nicola | Cod sursa (job #432848)
Cod sursa(job #432848)
#include <algorithm>
#include <vector>
#include <queue>
using namespace std;
#define pb push_back
#define DIM 1005
int f[DIM][DIM],c[DIM][DIM];
vector <int> g[DIM];
queue <int> q;
int n,m,flow;
int t[DIM];
void read ()
{
int i,x,y,z;
scanf ("%d%d",&n,&m);
for (i=1; i<=m; ++i)
{
scanf ("%d%d%d",&x,&y,&z);
g[x].pb (y);
g[y].pb (x);
c[x][y]=z;
}
}
inline int bf ()
{
vector <int> :: iterator it;
int nod;
memset (t,0,sizeof (t));
t[1]=-1;
for (q.push (1); !q.empty (); q.pop ())
{
nod=q.front ();
for (it=g[nod].begin (); it!=g[nod].end (); ++it)
if (!t[*it] && c[nod][*it]>f[nod][*it])
{
t[*it]=nod;
q.push (*it);
}
}
return t[n];
}
void solve ()
{
vector <int> :: iterator it;
int nrmin,i;
for ( ; bf (); )
for (it=g[n].begin (); it!=g[n].end (); ++it)
if (t[*it] && c[*it][n]>f[*it][n])
{
nrmin=c[*it][n]-f[*it][n];
for (i=*it; i!=1; i=t[i])
nrmin=min (nrmin,c[t[i]][i]-f[t[i]][i]);
f[*it][n]+=nrmin;
f[n][*it]-=nrmin;
for (i=*it; i!=1; i=t[i])
{
f[t[i]][i]+=nrmin;
f[i][t[i]]-=nrmin;
}
flow+=nrmin;
}
printf ("%d",flow);
}
int main ()
{
freopen ("maxflow.in","r",stdin);
freopen ("maxflow.out","w",stdout);
read ();
solve ();
return 0;
}