Submission #3477078
Source Code Expand
#include <bits/stdc++.h> using namespace std; using VS = vector<string>; using LL = long long; using VI = vector<int>; using VVI = vector<VI>; using PII = pair<int, int>; using PLL = pair<LL, LL>; using VL = vector<LL>; using VVL = vector<VL>; #define ALL(a) begin((a)),end((a)) #define RALL(a) (a).rbegin(), (a).rend() #define SZ(a) int((a).size()) #define SORT(c) sort(ALL((c))) #define RSORT(c) sort(RALL((c))) #define UNIQ(c) (c).erase(unique(ALL((c))), end((c))) #define FOR(i, s, e) for (int(i) = (s); (i) < (e); (i)++) #define FORR(i, s, e) for (int(i) = (s); (i) > (e); (i)--) //#pragma GCC optimize ("-O3") #ifdef YANG33 #include "mydebug.hpp" #else #define DD(x) #endif const int INF = 1e9; const LL LINF = 1e16; const LL MOD = 1000000007; const double PI = acos(-1.0); int DX[8] = { 0, 0, 1, -1, 1, 1, -1, -1 }; int DY[8] = { 1, -1, 0, 0, 1, -1, 1, -1 }; /* ----- 2018/10/24 Problem: ARC 035 D / Link: http://arc035.contest.atcoder.jp/tasks/arc035_d ----- */ /* ------問題------ -----問題ここまで----- */ /* -----解説等----- 頂点倍化UFをやればよい ----解説ここまで---- */ struct UnionFind { vector<int> data; UnionFind(int n) { data.assign(n, -1); } 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 same(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() { cin.tie(0); ios_base::sync_with_stdio(false); int N, Q; cin >> N >> Q; UnionFind uf(2 * N); FOR(i, 0, Q) { int w, x, y, z; cin >> w >> x >> y >> z; x--, y--; if (w == 1) { if (z % 2 == 1) { uf.unionSet(x, y + N); uf.unionSet(y, x + N); } else { uf.unionSet(x, y); uf.unionSet(y + N, x + N); } } else { if (uf.same(x, y)) { cout << "YES" << endl; } else { cout << "NO" << endl; } } //DD(de(w,z,y,z,uf)); } return 0; }
Submission Info
Submission Time | |
---|---|
Task | D - 偶数メートル |
User | Yang33 |
Language | C++14 (GCC 5.4.1) |
Score | 100 |
Code Size | 2205 Byte |
Status | AC |
Exec Time | 110 ms |
Memory | 1152 KB |
Judge Result
Set Name | Sample | Subtask1 | Subtask2 | ||||||
---|---|---|---|---|---|---|---|---|---|
Score / Max Score | 0 / 0 | 30 / 30 | 70 / 70 | ||||||
Status |
|
|
|
Set Name | Test Cases |
---|---|
Sample | sample_01.txt, sample_02.txt, sample_03.txt |
Subtask1 | sample_01.txt, sample_02.txt, sample_03.txt, subtask1_01.txt, subtask1_02.txt, subtask1_03.txt, subtask1_04.txt, subtask1_05.txt, subtask1_06.txt, subtask1_07.txt, subtask1_08.txt, subtask1_09.txt, subtask1_10.txt, subtask1_11.txt, subtask1_12.txt, subtask1_13.txt, subtask1_14.txt, subtask1_15.txt, subtask1_16.txt, subtask1_17.txt, subtask1_18.txt, subtask1_19.txt, subtask1_20.txt, subtask1_21.txt, subtask1_22.txt, subtask1_23.txt, subtask1_24.txt, subtask1_25.txt, subtask1_26.txt, subtask1_27.txt, subtask1_28.txt, subtask1_29.txt |
Subtask2 | sample_01.txt, sample_02.txt, sample_03.txt, subtask1_01.txt, subtask1_02.txt, subtask1_03.txt, subtask1_04.txt, subtask1_05.txt, subtask1_06.txt, subtask1_07.txt, subtask1_08.txt, subtask1_09.txt, subtask1_10.txt, subtask1_11.txt, subtask1_12.txt, subtask1_13.txt, subtask1_14.txt, subtask1_15.txt, subtask1_16.txt, subtask1_17.txt, subtask1_18.txt, subtask1_19.txt, subtask1_20.txt, subtask1_21.txt, subtask1_22.txt, subtask1_23.txt, subtask1_24.txt, subtask1_25.txt, subtask1_26.txt, subtask1_27.txt, subtask1_28.txt, subtask1_29.txt, subtask2_01.txt, subtask2_02.txt, subtask2_03.txt, subtask2_04.txt, subtask2_05.txt, subtask2_06.txt, subtask2_07.txt, subtask2_08.txt, subtask2_09.txt, subtask2_10.txt, subtask2_11.txt, subtask2_12.txt, subtask2_13.txt, subtask2_14.txt, subtask2_15.txt, subtask2_16.txt, subtask2_17.txt, subtask2_18.txt, subtask2_19.txt, subtask2_20.txt, subtask2_21.txt, subtask2_22.txt, subtask2_23.txt, subtask2_24.txt, subtask2_25.txt, subtask2_26.txt, subtask2_27.txt, subtask2_28.txt, subtask2_29.txt, subtask2_30.txt |
Case Name | Status | Exec Time | Memory |
---|---|---|---|
sample_01.txt | AC | 1 ms | 256 KB |
sample_02.txt | AC | 1 ms | 256 KB |
sample_03.txt | AC | 1 ms | 256 KB |
subtask1_01.txt | AC | 3 ms | 256 KB |
subtask1_02.txt | AC | 3 ms | 256 KB |
subtask1_03.txt | AC | 4 ms | 256 KB |
subtask1_04.txt | AC | 3 ms | 256 KB |
subtask1_05.txt | AC | 3 ms | 256 KB |
subtask1_06.txt | AC | 3 ms | 256 KB |
subtask1_07.txt | AC | 3 ms | 256 KB |
subtask1_08.txt | AC | 3 ms | 256 KB |
subtask1_09.txt | AC | 4 ms | 256 KB |
subtask1_10.txt | AC | 4 ms | 256 KB |
subtask1_11.txt | AC | 4 ms | 256 KB |
subtask1_12.txt | AC | 4 ms | 256 KB |
subtask1_13.txt | AC | 4 ms | 256 KB |
subtask1_14.txt | AC | 4 ms | 256 KB |
subtask1_15.txt | AC | 4 ms | 256 KB |
subtask1_16.txt | AC | 4 ms | 256 KB |
subtask1_17.txt | AC | 4 ms | 256 KB |
subtask1_18.txt | AC | 4 ms | 256 KB |
subtask1_19.txt | AC | 4 ms | 256 KB |
subtask1_20.txt | AC | 4 ms | 256 KB |
subtask1_21.txt | AC | 4 ms | 256 KB |
subtask1_22.txt | AC | 4 ms | 256 KB |
subtask1_23.txt | AC | 4 ms | 256 KB |
subtask1_24.txt | AC | 4 ms | 256 KB |
subtask1_25.txt | AC | 4 ms | 256 KB |
subtask1_26.txt | AC | 4 ms | 256 KB |
subtask1_27.txt | AC | 4 ms | 256 KB |
subtask1_28.txt | AC | 4 ms | 256 KB |
subtask1_29.txt | AC | 4 ms | 256 KB |
subtask2_01.txt | AC | 39 ms | 512 KB |
subtask2_02.txt | AC | 93 ms | 1152 KB |
subtask2_03.txt | AC | 7 ms | 512 KB |
subtask2_04.txt | AC | 88 ms | 896 KB |
subtask2_05.txt | AC | 39 ms | 1152 KB |
subtask2_06.txt | AC | 42 ms | 896 KB |
subtask2_07.txt | AC | 85 ms | 1152 KB |
subtask2_08.txt | AC | 93 ms | 896 KB |
subtask2_09.txt | AC | 59 ms | 640 KB |
subtask2_10.txt | AC | 106 ms | 1152 KB |
subtask2_11.txt | AC | 108 ms | 1152 KB |
subtask2_12.txt | AC | 107 ms | 1152 KB |
subtask2_13.txt | AC | 110 ms | 1152 KB |
subtask2_14.txt | AC | 107 ms | 1152 KB |
subtask2_15.txt | AC | 107 ms | 1152 KB |
subtask2_16.txt | AC | 108 ms | 1152 KB |
subtask2_17.txt | AC | 107 ms | 1152 KB |
subtask2_18.txt | AC | 108 ms | 1152 KB |
subtask2_19.txt | AC | 107 ms | 1152 KB |
subtask2_20.txt | AC | 108 ms | 1152 KB |
subtask2_21.txt | AC | 36 ms | 1024 KB |
subtask2_22.txt | AC | 36 ms | 1024 KB |
subtask2_23.txt | AC | 36 ms | 1024 KB |
subtask2_24.txt | AC | 36 ms | 1024 KB |
subtask2_25.txt | AC | 36 ms | 1024 KB |
subtask2_26.txt | AC | 36 ms | 1024 KB |
subtask2_27.txt | AC | 37 ms | 1024 KB |
subtask2_28.txt | AC | 36 ms | 1024 KB |
subtask2_29.txt | AC | 36 ms | 1024 KB |
subtask2_30.txt | AC | 102 ms | 768 KB |