HDU - 1054 Strategic Game (二分图匹配模板题)

时间:2023-03-10 07:10:38
HDU - 1054 Strategic Game (二分图匹配模板题)

二分图匹配模板题

#include <bits/stdc++.h>
#define FOPI freopen("in.txt", "r", stdin);
#define FOPO freopen("out.txt", "w", stdout);
using namespace std;
typedef long long LL;
const int maxn = + ;
int n, k, x, y;
int link[maxn], vis[maxn];
vector<int> v[maxn]; void build(int x, int y)
{
v[x].push_back(y), v[y].push_back(x);
} bool dfs(int k)
{
int sz = v[k].size();
for (int i = ; i < sz; i++)
{
if (!vis[v[k][i]])
{
vis[v[k][i]] = ;
if (link[v[k][i]] == - || dfs(link[v[k][i]]))
{
link[v[k][i]] = k;
return true;
}
}
}
return false;
} int hungary()
{
int u;
int res = ;
memset(link, -, sizeof(link));
for (int i = ; i < n; i++)
{
memset(vis, , sizeof(vis));
if (dfs(i)) res++;
}
return res;
} int main()
{
while(~scanf("%d", &n))
{
for (int i = ; i < n; i++) v[i].clear();
for (int i = ; i <= n; i++)
{
scanf("%d:(%d)", &x, &k);
for (int j = ; j <= k; j++)
scanf("%d", &y), build(x, y), build(y, x);
}
printf("%d\n", hungary()/);
}
}