Submission #66720
ソースコード
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 | #include <iostream> #include <vector> using namespace std; int main(){ cin.tie(nullptr); ios_base::sync_with_stdio( false ); int n; cin >> n; vector< int > p(n + 1), e(n + 1); for ( int i = 2; i <= n; ++i){ cin >> p[i] >> e[i]; } int q; cin >> q; vector< bool > parity(n + 1); for ( int i = 0; i < q; ++i){ int s, t; cin >> s >> t; vector< int > edges1, edges2; while (s != t){ int dep_s = 32 - __builtin_clz(s); int dep_t = 32 - __builtin_clz(t); if (dep_s == dep_t){ edges1.emplace_back(s); edges2.emplace_back(t); s >>= 1; t >>= 1; } else if (dep_s > dep_t){ edges1.emplace_back(s); s >>= 1; } else { edges2.emplace_back(t); t >>= 1; } } vector< int > edges; copy(edges1.begin(), edges1.end(), back_inserter(edges)); copy(edges2.rbegin(), edges2.rend(), back_inserter(edges)); bool ok = true ; for (auto edge: edges){ ok &= parity[e[edge]] == p[edge]; parity[edge].flip(); } if (ok){ cout << "Yes\n" ; } else { cout << "No\n" ; } for (auto edge: edges){ parity[edge] = 0; } } return (0); } |
ステータス
項目 | データ |
---|---|
問題 | 1511 - Binary Tree |
ユーザー名 | ei1903 |
投稿日時 | 2021-05-16 20:52:54 |
言語 | C++17 |
状態 | Accepted |
得点 | 4 |
ソースコード長 | 1505 Byte |
最大実行時間 | 132 ms |
最大メモリ使用量 | 11116 KB |
セット
セット | 得点 | Cases | |
---|---|---|---|
1 | ALL | 4 / 4 | * |
テストケース
ファイル名 | 状態 | 実行時間 | メモリ使用量 | # |
---|---|---|---|---|
in01.txt | AC | 36 ms | 604 KB |
1
|
in02.txt | AC | 28 ms | 436 KB |
1
|
in03.txt | AC | 90 ms | 776 KB |
1
|
in04.txt | AC | 42 ms | 1080 KB |
1
|
in05.txt | AC | 57 ms | 912 KB |
1
|
in06.txt | AC | 60 ms | 1364 KB |
1
|
in07.txt | AC | 38 ms | 1588 KB |
1
|
in08.txt | AC | 77 ms | 1292 KB |
1
|
in09.txt | AC | 108 ms | 1976 KB |
1
|
in10.txt | AC | 120 ms | 2476 KB |
1
|
in11.txt | AC | 123 ms | 2824 KB |
1
|
in12.txt | AC | 119 ms | 3172 KB |
1
|
in13.txt | AC | 122 ms | 3680 KB |
1
|
in14.txt | AC | 124 ms | 3848 KB |
1
|
in15.txt | AC | 123 ms | 4148 KB |
1
|
in16.txt | AC | 132 ms | 4444 KB |
1
|
in17.txt | AC | 128 ms | 4612 KB |
1
|
in18.txt | AC | 107 ms | 4804 KB |
1
|
in19.txt | AC | 99 ms | 4908 KB |
1
|
in20.txt | AC | 110 ms | 5408 KB |
1
|
in21.txt | AC | 99 ms | 5620 KB |
1
|
in22.txt | AC | 132 ms | 6040 KB |
1
|
in23.txt | AC | 120 ms | 6604 KB |
1
|
in24.txt | AC | 99 ms | 6596 KB |
1
|
in25.txt | AC | 120 ms | 7264 KB |
1
|
in26.txt | AC | 131 ms | 7776 KB |
1
|
in27.txt | AC | 131 ms | 8072 KB |
1
|
in28.txt | AC | 125 ms | 8368 KB |
1
|
in29.txt | AC | 124 ms | 8800 KB |
1
|
in30.txt | AC | 120 ms | 9100 KB |
1
|
in31.txt | AC | 114 ms | 9404 KB |
1
|
in32.txt | AC | 125 ms | 9832 KB |
1
|
in33.txt | AC | 127 ms | 10008 KB |
1
|
in34.txt | AC | 82 ms | 10440 KB |
1
|
in35.txt | AC | 79 ms | 10868 KB |
1
|
in36.txt | AC | 36 ms | 10528 KB |
1
|
in37.txt | AC | 103 ms | 11116 KB |
1
|
sample01.txt | AC | 22 ms | 10664 KB |
1
|
sample02.txt | AC | 24 ms | 10624 KB |
1
|