题解:P3386 【模板】二分图最大匹配
匈牙利算法
我们用一个二维数组来存图,然后遍历
核心代码
bool dfs(int u) {
for (int i = 1; i <= m; i++) {
if (f[u][i] && !vis[i]) {
vis[i] = 1;
if (!match[i] || dfs(match[i])) {
match[i] = u;
return 1;
}
}
}
return 0;
}
遍历
代码
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<vector>
#include<cmath>
using namespace std;
const int N = 1e3;
bool f[N][N];
bool vis[N];
int match[N], n, m, e;
bool dfs(int u) {
for (int i = 1; i <= m; i++) {
if (f[u][i] && !vis[i]) {
vis[i] = 1;
if (!match[i] || dfs(match[i])) {
match[i] = u;
return 1;
}
}
}
return 0;
}
int main() {
scanf("%d%d%d", &n, &m, &e);
for (int i = 1; i <= e; i++) {
int x, y;
scanf("%d%d", &x, &y);
f[x][y] = 1;
}
int ans = 0;
for (int i = 1; i <= n; i++) {
memset(vis, 0, sizeof(vis));
if (dfs(i)) ans++;
}
printf("%d\n", ans);
return 0;
}