#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<vector>
using namespace std;
#define N 1005
int link[N], vis[N];
vector<int> v[N];
int n;
int dfs( int u )
{
for( int i = 0; i < v[u].size(); i++ )
{
int to = v[u][i];
if( !vis[to] )
{
vis[to] = 1;
if( link[to] == -1 || dfs( link[to] ) )
{
link[to] = u;
return 1;
}
}
}
return 0;
}
int main()
{
while(~scanf("%d", &n))
{
for( int i = 0; i < n; i ++ )
v[i].clear();
int x;
for(int i = 0; i < n; i ++)
{
scanf("%d: (%d)", &i, &x);
while(x--)
{
int z;
scanf("%d", &z);
v[i].push_back(z);
}
}
memset(link, -1, sizeof(link));
int ans = 0;
for( int i = 0; i < n; i++ )
{
memset(vis, 0, sizeof(vis));
ans += dfs(i);
}
printf("%d\n", n - ans / 2);
}
return 0;
}hdu 1068 Girls and Boys
最新推荐文章于 2024-07-29 10:00:00 发布
本文介绍了一种基于二分匹配算法的实现方法,通过使用深度优先搜索(DFS)来寻找图中的最大匹配。该算法首先定义了必要的数据结构,如邻接表表示图的结构,并初始化了一些辅助数组用于记录节点的状态。然后,通过递归调用深度优先搜索尝试为每个未匹配的节点找到一个匹配。最后,根据匹配情况计算并输出未配对的节点数。


662

被折叠的 条评论
为什么被折叠?



