Pagini recente » Cod sursa (job #2138553) | Cod sursa (job #1401827) | Cod sursa (job #1841267) | Cod sursa (job #1972793) | Cod sursa (job #2162651)
#include <fstream>
#define nmax 1002
using namespace std;
ifstream fin("maxflow.in");
ofstream fout("maxflow.out");
int mini,flux=0;
int a[nmax][nmax],cost[nmax][nmax],n,m,x,y,val;
int dfs(int nod)
{
if(nod==1)
{
mini=1000000;
}
for(int i=1;i<=n;i++)
{
if(a[nod][i])
{
mini=min(cost[nod][i],mini);
if(i==n)
{
cost[nod][i]-=mini;
if(!cost[nod][i])
a[nod][i]=0;
flux+=mini;
return 1;
}
if(dfs(i))
{
cost[nod][i]-=mini;
if(!cost[nod][i])
a[nod][i]=0;
i--;
if(nod==1)
continue;
else
break;
}
}
}
}
int main()
{
fin>>n>>m;
for(int i=1;i<=m;i++)
{
fin>>x>>y>>val;
a[x][y]=1;
cost[x][y]=val;
}
dfs(1);
fout<<flux;
return 0;
}