想一想最小點覆寫時的那種性質,很容易就會産生要把能生産一種産品的機器連線的想法。我今天看這個題,又像以前一樣,看着看着就自動把題意給忘了然後自己進行了腦補,誤以為一個産品能用一台機器的一種以上模式生産,結果不能建圖,以後一定引以為戒!
另一個神奇之處就是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;
}