Submission #366760

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

int size;
bool remain[80][80];

void initialize(int n) {
    assert(n <= 80);
    size = n;
    for (int i = 0; i < size; ++i) {
        for (int j = 0; j < size; ++j) {
            remain[i][j] = (i != j);
        }
    }    
}

struct DSU {
    std::vector<int> par;
    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;
    }
};

bool isConnected() {
    int cnt = 0;
    DSU dsu(size);
    for (int i = 0; i < size; ++i) {
        for (int j = 0; j < size; ++j) {
            if (remain[i][j]) {
                if (dsu.merge(i, j)) {
                    cnt += 1;
                }
            }
        }
    }
    return cnt == size - 1;
}

int hasEdge(int u, int v) {
    remain[u][v] = false;
    if (isConnected()) {
        return 0;
    }
    else {
        remain[u][v] = true;
        return 1;
    }
}
# Verdict Execution time Memory Grader output
1 Incorrect 1 ms 364 KB Output isn't correct
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 1 ms 364 KB Output isn't correct
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 1 ms 364 KB Output isn't correct
2 Halted 0 ms 0 KB -