标签:
Matrix2
//最小顶点覆盖=最大匹配
#include <stdio.h>
#include <string.h>
int ma[110][110];
int n,m;
bool vis[110];
int link[110];
bool Find(int x)
{
for(int i=0;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()
{
while(~scanf("%d",&n)&&n)
{
scanf("%d",&m);
memset(link,-1,sizeof(link));
for(int i=0;i<n;i++)
for(int k=0;k<m;k++)
scanf("%d",&ma[i][k]);
int ans=0;
for(int i=0;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/47379447