This documentation is automatically generated by competitive-verifier/competitive-verifier
// competitive-verifier: PROBLEM https://onlinejudge.u-aizu.ac.jp/problems/0723
#include "tree/undo_union_find.hpp"
#include <algorithm>
#include <iostream>
#include <map>
#include <vector>
int main(void) {
int n, m, k;
std::cin >> n >> m >> k;
std::vector<std::pair<int, int>> edges(m);
for (auto &[x, y] : edges) std::cin >> x >> y, --x, --y;
std::vector<int> s(n);
for (int &e : s) std::cin >> e;
int q;
std::cin >> q;
std::vector<std::pair<int, int>> queries(q);
for (auto &[x, y] : queries) std::cin >> x >> y, --x, --y;
undo_union_find uf(n);
std::map<std::pair<int, int>, std::vector<int>> mp;
for (int i = 0; i < m; ++i) {
auto [x, y] = edges[i];
if (s[x] == s[y]) {
uf.unite(x, y);
} else {
if (s[x] > s[y]) std::swap(x, y);
mp[{s[x], s[y]}].emplace_back(i);
}
}
std::vector<int> ans(q, -1);
std::map<std::pair<int, int>, std::vector<int>> pm;
for (int i = 0; i < q; ++i) {
auto [x, y] = queries[i];
if (s[x] == s[y]) {
ans[i] = uf.same(x, y);
} else {
if (s[x] > s[y]) std::swap(x, y);
pm[{s[x], s[y]}].emplace_back(i);
}
}
int snap = uf.snapshot();
for (auto &[p, v] : pm) {
for (auto e : mp[p]) uf.unite(edges[e].first, edges[e].second);
for (auto e : v) ans[e] = uf.same(queries[e].first, queries[e].second);
uf.rollback(snap);
}
for (int i = 0; i < q; ++i) std::cout << ans[i] << '\n';
return 0;
}
Traceback (most recent call last):
File "/home/runner/.local/lib/python3.12/site-packages/competitive_verifier/oj/resolver.py", line 291, in resolve
bundled_code = language.bundle(path, basedir=basedir)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/home/runner/.local/lib/python3.12/site-packages/competitive_verifier/oj/verify/languages/cplusplus.py", line 242, in bundle
bundler.update(path)
File "/home/runner/.local/lib/python3.12/site-packages/competitive_verifier/oj/verify/languages/cplusplus_bundle.py", line 479, in update
self._resolve(pathlib.Path(included), included_from=path)
File "/home/runner/.local/lib/python3.12/site-packages/competitive_verifier/oj/verify/languages/cplusplus_bundle.py", line 286, in _resolve
raise BundleErrorAt(path, -1, "no such header")
competitive_verifier.oj.verify.languages.cplusplus_bundle.BundleErrorAt: tree/undo_union_find.hpp: line -1: no such header
| Env | Name | Status | Elapsed | Memory |
|---|---|---|---|---|
| g++ | 00-sample-01 |
|
3 ms | 4 MB |
| g++ | 00-sample-02 |
|
2 ms | 3 MB |
| g++ | 00-sample-03 |
|
2 ms | 4 MB |
| g++ | 00-sample-04 |
|
2 ms | 4 MB |
| g++ | 01-01 |
|
3 ms | 4 MB |
| g++ | 01-02 |
|
3 ms | 4 MB |
| g++ | 01-03 |
|
3 ms | 4 MB |
| g++ | 01-04 |
|
3 ms | 4 MB |
| g++ | 01-05 |
|
3 ms | 4 MB |
| g++ | 01-06 |
|
3 ms | 4 MB |
| g++ | 01-07 |
|
3 ms | 4 MB |
| g++ | 01-08 |
|
3 ms | 4 MB |
| g++ | 01-09 |
|
3 ms | 4 MB |
| g++ | 01-10 |
|
3 ms | 4 MB |
| g++ | 01-11 |
|
3 ms | 4 MB |
| g++ | 01-12 |
|
4 ms | 4 MB |
| g++ | 01-13 |
|
3 ms | 4 MB |
| g++ | 01-14 |
|
3 ms | 4 MB |
| g++ | 01-15 |
|
2 ms | 4 MB |
| g++ | 01-16 |
|
3 ms | 4 MB |
| g++ | 01-17 |
|
3 ms | 4 MB |
| g++ | 01-18 |
|
3 ms | 4 MB |
| g++ | 01-19 |
|
3 ms | 4 MB |
| g++ | 01-20 |
|
3 ms | 4 MB |
| g++ | 01-21 |
|
3 ms | 4 MB |
| g++ | 01-22 |
|
3 ms | 4 MB |
| g++ | 01-23 |
|
2 ms | 3 MB |
| g++ | 01-24 |
|
2 ms | 3 MB |
| g++ | 03-01 |
|
148 ms | 22 MB |
| g++ | 03-02 |
|
140 ms | 22 MB |
| g++ | 03-03 |
|
150 ms | 22 MB |
| g++ | 03-04 |
|
119 ms | 15 MB |
| g++ | 03-05 |
|
143 ms | 22 MB |
| g++ | 03-06 |
|
125 ms | 14 MB |
| g++ | 03-07 |
|
124 ms | 14 MB |
| g++ | 03-08 |
|
134 ms | 17 MB |
| g++ | 03-09 |
|
146 ms | 18 MB |
| g++ | 03-10 |
|
142 ms | 20 MB |
| g++ | 03-11 |
|
79 ms | 7 MB |
| g++ | 03-12 |
|
191 ms | 29 MB |
| g++ | 03-13 |
|
83 ms | 11 MB |
| g++ | 03-14 |
|
164 ms | 27 MB |
| g++ | 03-15 |
|
49 ms | 6 MB |
| g++ | 03-16 |
|
62 ms | 6 MB |
| g++ | 03-17 |
|
105 ms | 10 MB |
| g++ | 03-18 |
|
148 ms | 26 MB |
| g++ | 03-19 |
|
48 ms | 5 MB |
| g++ | 03-20 |
|
65 ms | 6 MB |
| g++ | 03-21 |
|
79 ms | 7 MB |
| g++ | 03-22 |
|
80 ms | 7 MB |
| g++ | 03-23 |
|
42 ms | 6 MB |
| g++ | 04-01 |
|
854 ms | 96 MB |
| g++ | 04-02 |
|
838 ms | 96 MB |
| g++ | 04-03 |
|
1010 ms | 97 MB |
| g++ | 04-04 |
|
781 ms | 55 MB |
| g++ | 04-05 |
|
858 ms | 96 MB |
| g++ | 04-06 |
|
785 ms | 59 MB |
| g++ | 04-07 |
|
781 ms | 59 MB |
| g++ | 04-08 |
|
857 ms | 72 MB |
| g++ | 04-09 |
|
893 ms | 79 MB |
| g++ | 04-10 |
|
881 ms | 86 MB |
| g++ | 04-11 |
|
421 ms | 21 MB |
| g++ | 04-12 |
|
1276 ms | 133 MB |
| g++ | 04-13 |
|
548 ms | 44 MB |
| g++ | 04-14 |
|
1118 ms | 129 MB |
| g++ | 04-15 |
|
218 ms | 13 MB |
| g++ | 04-16 |
|
351 ms | 17 MB |
| g++ | 04-17 |
|
672 ms | 35 MB |
| g++ | 04-18 |
|
907 ms | 105 MB |
| g++ | 04-19 |
|
262 ms | 16 MB |
| g++ | 04-20 |
|
343 ms | 16 MB |
| g++ | 04-21 |
|
389 ms | 23 MB |
| g++ | 04-22 |
|
421 ms | 23 MB |
| g++ | 04-23 |
|
212 ms | 16 MB |