想一想最小点覆盖时的那种性质,很容易就会产生要把能生产一种产品的机器连线的想法。我今天看这个题,又像以前一样,看着看着就自动把题意给忘了然后自己进行了脑补,误以为一个产品能用一台机器的一种以上模式生产,结果不能建图,以后一定引以为戒!
另一个神奇之处就是mod_0这个事。显然,能用mod_0及解决的产品根本就不用参与匹配。一开始想在一开始对产品进行处理,但其实这很傻,聪明的做法是进行匈牙利算法的时候不枚举0这个点。
#include<iostream>
#include<cstdio>
#include<string.h>
#include<algorithm>
using namespace std;
int n,m,k,line[210][210],girl[210],used[210];
bool find(int x)
{
int i,j;
for (int j=1; j<m; j++)
{
if (line[x][j] && !used[j])
{
used[j]=1;
if (girl[j]==-1 || find(girl[j]))
{
girl[j]=x;
return true;
}
}
}
return false;
}
int main()
{
while (~scanf("%d",&n) && n)
{
scanf("%d%d",&m,&k);
memset(line,0,sizeof(line));
for (int i=1; i<=k; i++)
{
int z,x,y;
scanf("%d%d%d",&z,&x,&y);
line[x][y]=1;
}
int all=0;
memset(girl,-1,sizeof(girl));
for (int i=1; i<n; i++)
{
memset(used,0,sizeof(used));
if (find(i)) all++;
}
cout<<all<<endl;
}
return 0;
}