Submission #423154


Source Code Expand

#include <iostream>
#include <string>
#include <algorithm>
#include <iomanip>
#include <vector>

using namespace std;

struct UnionFind {
  int data[200001];
  UnionFind() {
    fill_n(data, 200001, 0);
  }
  bool unionSet(int x, int y) {
    x = root(x); y = root(y);
    if (x != y) {
      if (data[y] < data[x]) swap(x, y);
      data[x] += data[y]; data[y] = x;
    }
    return x != y;
  }
  bool findSet(int x, int y) {
    return root(x) == root(y);
  }
  int root(int x) {
    return data[x] < 0 ? x : data[x] = root(data[x]);
  }
  int size(int x) {
    return -data[root(x)];
  }
};

int main() {
  int N, Q;
  int P, A, B;

  UnionFind uf;

  cin >> N >> Q;
  for (int i = 0; i < Q; ++i) {
    cin >> P >> A >> B;
    if (P == 0) {
      uf.unionSet(A, B);
    }
    if (P == 1) {
      if (uf.findSet(A, B)) {
        cout << "Yes" << endl;
      }else {
        cout << "No" << endl;
      }

    }
  }
  return 0;
}

Submission Info

Submission Time
Task B - Union Find
User otomarukanta
Language C++ (GCC 4.9.2)
Score 0
Code Size 984 Byte
Status MLE
Exec Time 862 ms
Memory 256792 KB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 0 / 100
Status
MLE × 1
MLE × 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 MLE 862 ms 256728 KB
subtask_01_01.txt MLE 804 ms 256672 KB
subtask_01_02.txt MLE 796 ms 256664 KB
subtask_01_03.txt MLE 802 ms 256676 KB
subtask_01_04.txt MLE 800 ms 256668 KB
subtask_01_05.txt MLE 796 ms 256668 KB
subtask_01_06.txt MLE 807 ms 256668 KB
subtask_01_07.txt MLE 809 ms 256664 KB
subtask_01_08.txt MLE 798 ms 256672 KB
subtask_01_09.txt MLE 799 ms 256664 KB
subtask_01_10.txt MLE 801 ms 256792 KB
subtask_01_11.txt MLE 801 ms 256668 KB
subtask_01_12.txt MLE 797 ms 256668 KB
subtask_01_13.txt MLE 798 ms 256676 KB
subtask_01_14.txt MLE 806 ms 256676 KB
subtask_01_15.txt MLE 805 ms 256676 KB
subtask_01_16.txt MLE 801 ms 256676 KB
subtask_01_17.txt MLE 800 ms 256680 KB
subtask_01_18.txt MLE 801 ms 256664 KB