Submission #3460765


Source Code Expand

#include <iostream>
#include <vector>

using namespace std;

const int MAX_V = 100010;

class UnionFind {
public:
    // コンストラクタ
    explicit UnionFind(int N) : V_NUM(N) {
        for (int i = 0; i < V_NUM; ++i) {
            par[i] = i;
        }
        fill(rank, rank + V_NUM, 0);
        fill(num, num + V_NUM, 1);
    }

    // xの親を返す+更新
    int find(int x) {
        if (par[x] == x) {
            return x;
        } else {
            return par[x] = find(par[x]);
        }
    }

    // xとyを含むグループを統合する
    void unite(int x, int y) {
        x = find(x);
        y = find(y);

        if (x == y) return;

        // rank[x] >= rank[y]にする
        if (rank[x] < rank[y]) swap(x, y);

        // rankの大きい方、つまりxにyをくっつける
        num[x] += num[y];
        par[y] = x;
        if (rank[x] == rank[y]) ++rank[x];
    }

    // xとyが同じグループに属するか判定
    bool same(int x, int y) {
        return find(x) == find(y);
    }

    int V_NUM;
    int par[MAX_V], rank[MAX_V], num[MAX_V];
};

int main() {
    int N, Q;
    cin >> N >> Q;

    UnionFind uf(N);

    for (int q = 0; q < Q; ++q) {
        int p, a, b;
        cin >> p >> a >> b;

        if (p == 0) {
            uf.unite(a, b);
        } else {
            cout << (uf.same(a, b) ? "Yes" : "No") << endl;
        }
    }
    return 0;
}

Submission Info

Submission Time
Task B - Union Find
User Tiramister
Language C++14 (GCC 5.4.1)
Score 100
Code Size 1489 Byte
Status AC
Exec Time 496 ms
Memory 2048 KB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 100 / 100
Status
AC × 1
AC × 19
Set Name Test Cases
Sample 00_sample_01.txt
All 00_sample_01.txt, subtask_01_01.txt, subtask_01_02.txt, subtask_01_03.txt, subtask_01_04.txt, subtask_01_05.txt, subtask_01_06.txt, subtask_01_07.txt, subtask_01_08.txt, subtask_01_09.txt, subtask_01_10.txt, subtask_01_11.txt, subtask_01_12.txt, subtask_01_13.txt, subtask_01_14.txt, subtask_01_15.txt, subtask_01_16.txt, subtask_01_17.txt, subtask_01_18.txt
Case Name Status Exec Time Memory
00_sample_01.txt AC 1 ms 256 KB
subtask_01_01.txt AC 286 ms 768 KB
subtask_01_02.txt AC 2 ms 1408 KB
subtask_01_03.txt AC 420 ms 1024 KB
subtask_01_04.txt AC 496 ms 2048 KB
subtask_01_05.txt AC 25 ms 256 KB
subtask_01_06.txt AC 28 ms 1408 KB
subtask_01_07.txt AC 485 ms 896 KB
subtask_01_08.txt AC 494 ms 2048 KB
subtask_01_09.txt AC 1 ms 256 KB
subtask_01_10.txt AC 2 ms 1408 KB
subtask_01_11.txt AC 428 ms 896 KB
subtask_01_12.txt AC 496 ms 2048 KB
subtask_01_13.txt AC 381 ms 768 KB
subtask_01_14.txt AC 3 ms 1408 KB
subtask_01_15.txt AC 439 ms 896 KB
subtask_01_16.txt AC 495 ms 2048 KB
subtask_01_17.txt AC 342 ms 1792 KB
subtask_01_18.txt AC 338 ms 1792 KB