标签:
过山车3
//匈牙利算法 最大匹配
#include <stdio.h>
#include <string.h>
int ma[1010][1010];
int vis[1010],link[1010]; //和女生相连的男生
int n,m;
bool Find(int x)
{
for(int i=1;i<=m;i++)
{
if(!vis[i]&&ma[x][i])
{
vis[i]=1;
if(link[i]==-1||Find(link[i]))
{
link[i]=x;
return true;
}
}
}
return false;
}
int main()
{
int k;//link的个数
while(~scanf("%d",&k)&&k)
{
int a,b;
memset(link,-1,sizeof(link));
memset(ma,0,sizeof(ma));
scanf("%d%d",&n,&m);
for(int i=0;i<k;i++)
{
scanf("%d%d",&a,&b);
ma[a][b]=1;
}
int ans=0;
for(int i=1;i<=n;i++)
{
memset(vis,0,sizeof(vis));
if(Find(i))
{
ans++;
}
}
printf("%d\n",ans);
}
return 0;
}版权声明:本文为博主原创文章,未经博主允许不得转载。
标签:
原文地址:http://blog.csdn.net/a73265/article/details/47379355