您的位置:首页 > 其它

poj 3041 Asteroids(二分图最小顶点覆盖)

2012-12-15 20:10 399 查看
题目:http://poj.org/problem?id=3041

把X作为n1点集,y作为n2点集,x->y建立二分图,最小顶点覆盖。。

View Code

#include <iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int n,k;
int map[505][505];
int vis[505];
int link[505];
int find(int x)
{
int i;
for(i=1;i<=n;i++)
{
if(map[x][i]&&!vis[i])
{
vis[i]=1;
if(link[i]==0||find(link[i]))
{
link[i]=x;
return 1;
}
}
}
return 0;
}
int main()
{
int x,y,i;
scanf("%d%d",&n,&k);
memset(map,0,sizeof(map));
for(i=0;i<k;i++)
{
scanf("%d%d",&x,&y);
map[x][y]=1;
}
int num=0;
for(i=1;i<=n;i++)
{
memset(vis,0,sizeof(vis));
if(find(i))
num++;
}
printf("%d\n",num);
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: