Submission #366786

# Submission time Handle Problem Language Result Execution time Memory
366786 2021-02-15T09:50:22 Z KoD Game (IOI14_game) C++17
0 / 100
1 ms 364 KB
#include <bits/stdc++.h>

struct DSU {
    std::vector<int> par;
    DSU() { }
    DSU(const int n): par(n, -1) { }
    int find(const int u) {
        return par[u] < 0 ? u : par[u] = find(par[u]);
    }
    bool merge(int u, int v) {
        u = find(u);
        v = find(v);
        if (u == v) {
            return false;
        }
        if (par[u] > par[v]) {
            std::swap(u, v);
        }
        par[u] += par[v];
        par[v] = u;
        return true;
    }
};

DSU dsu;
int N;
int count[2000][2000];

void initialize(int n) {
    N = n;
    dsu = DSU(n);
    for (int i = 0; i < n; ++i) {
        for (int j = 0; j < n; ++j) {
            if (i != j) {
                count[i][j] = 1;
            }
        }
    }
}

int hasEdge(int u, int v) {
    u = dsu.find(u);
    v = dsu.find(v);
    if (count[u][v] == 1) {
        for (int i = 0; i < N; ++i) {
            count[u][i] += count[v][i];
            count[i][u] += count[v][i];
        }
        dsu.merge(u, v);
        return 1;
    }
    else {
        count[u][v] -= 1;
        count[v][u] -= 1;
        return 0;
    }
}

#ifdef __APPLE__
int main() {
    int n;
    std::cin >> n;
    initialize(n);
    for (int i = 0; i < n; ++i) {
        for (int j = 0; j < i; ++j) {
            int u, v;
            std::cin >> u >> v;
            std::cout << hasEdge(u, v) << '\n';
        }
    }
}
#endif
# Verdict Execution time Memory Grader output
1 Correct 1 ms 364 KB Output is correct
2 Correct 0 ms 364 KB Output is correct
3 Correct 1 ms 364 KB Output is correct
4 Correct 0 ms 364 KB Output is correct
5 Correct 1 ms 364 KB Output is correct
6 Incorrect 0 ms 364 KB Output isn't correct
7 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 1 ms 364 KB Output is correct
2 Correct 1 ms 364 KB Output is correct
3 Correct 1 ms 364 KB Output is correct
4 Correct 1 ms 364 KB Output is correct
5 Correct 1 ms 364 KB Output is correct
6 Incorrect 0 ms 364 KB Output isn't correct
7 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 0 ms 364 KB Output is correct
2 Correct 0 ms 364 KB Output is correct
3 Correct 1 ms 364 KB Output is correct
4 Correct 1 ms 364 KB Output is correct
5 Correct 0 ms 364 KB Output is correct
6 Incorrect 1 ms 364 KB Output isn't correct
7 Halted 0 ms 0 KB -