
最大流KK算法
#include<iostream>
#include<stdio.h>
#include<string.h>
#include<math.h>
#include<algorithm>
#define MAX 0x3f3f3f3f
using namespace std; int map[][];
int pre[];
int n,m; int DFS(int s, int t, int f)
{
if(s==t)
return f;//找到终点了,此时剩下的流量就是能获得的流量
for(int i=; i<=n; i++)
{
if(map[s][i]> && pre[i]==)//从s开始找
{
pre[i]=;
int d=DFS(i,t,min(f,map[s][i]));//问有没有增广路
if(d>)
{
map[s][i] -= d;
map[i][s] += d;
return d;
}
}
}
return ;
} int KK(int s, int t)
{
int maxflow=;
while(true)
{
memset(pre, , sizeof(pre));
int f= DFS(s,t,MAX);//不断找s到t的增广路
if(f == )
return maxflow; //找不到了就回去
maxflow += f;//找到一个流量f的就赚了
}
} int main()
{
while(~scanf("%d %d", &m, &n))
{
memset(map,,sizeof(map));
int a,b,c;
for(int i=; i<=m; i++)
{
scanf("%d %d %d", &a, &b, &c);
map[a][b] += c;
}
int ans=KK(,n);
printf("%d\n", ans);
}
return ;
}