-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathmatching.cpp
52 lines (45 loc) · 1 KB
/
matching.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
int match[3][MAXN]; // 0 for first part, 1 for second part
bool mark[MAXN];
vector<int> adj[MAXN]; // adjacent list for first part nodes
int n, m, p;
// n: number of nodes in first part
// m: number of nodes in second part
// p: number of edges
bool dfs(int x) {
if (mark[x]) return false;
mark[x] = true;
for (int i = 0; i < SZ(adj[x]); i ++) {
int v = adj[x][i];
if (match[1][v] == -1 || dfs(match[1][v])) {
match[0][x] = v;
match[1][v] = x;
return true;
}
}
return false;
}
void bi_match() {
CLR(match, -1);
for (int i = 0; i < n; i ++) {
CLR(mark, 0);
bool check = false;
for (int j = 0; j < n; j ++)
if (!mark[j] && match[0][j] == -1)
check |= dfs(j);
if (!check) break;
}
}
int main () {
cin >> n >> m >> p;
for (int i = 0; i < p; i ++) {
int x, y; cin >> x >> y; x --, y --;
// x: a node in first part [0, n)
// y: a node in second part [0, m)
adj[x].pb(y);
}
bi_match();
int ans = 0;
FOR(i, n) ans += (match[0][i] != -1);
cout << ans << endl;
return 0;
}