# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
95442 | choikiwon | Marriage questions (IZhO14_marriage) | C++17 | 1575 ms | 5864 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int MN = 100010;
int N, M, K;
vector<int> adj[MN], U, V;
int matched[MN], chk[MN], who[MN], vis[MN];
bool dfs(int u, int t, int lb, int ub) {
vis[u] = 1;
if(t && !chk[u]) {
chk[u] = 1;
return true;
}
for(int i = 0; i < adj[u].size(); i++) {
int e = adj[u][i];
int v = U[e] + V[e] - u;
if(v < N && (v < lb || ub < v)) continue;
if(vis[v]) continue;
if(matched[e] == t && dfs(v, t ^ 1, lb, ub)) {
if(!t) {
who[u] = e;
who[v] = e;
}
matched[e] ^= 1;
return true;
}
}
return false;
}
int main() {
scanf("%d %d %d", &N, &M, &K);
for(int i = 0; i < K; i++) {
int a, b; scanf("%d %d", &a, &b);
a--; b--;
adj[a].push_back(i);
adj[b + N].push_back(i);
U.push_back(a);
V.push_back(b + N);
}
ll ans = 0;
int matching = 0;
int j = 0;
for(int i = 0; i < N; i++) {
while(j < N && matching < M) {
for(int k = 0; k < N + M; k++) vis[k] = 0;
if(dfs(j, 0, i, j)) {
matching++;
chk[j] = 1;
}
j++;
}
if(matching < M) break;
ans += N - j + 1;
if(chk[i]) {
matching--;
int v = U[ who[i] ] + V[ who[i] ] - i;
matched[ who[i] ] = 0;
chk[v] = 0;
for(int k = 0; k < N + M; k++) vis[k] = 0;
if(dfs(v, 0, i + 1, j)) {
matching++;
chk[v] = 1;
}
}
}
printf("%lld", ans);
}
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |