algo

This documentation is automatically generated by competitive-verifier/competitive-verifier

View the Project on GitHub kuhaku-space/algo

:heavy_check_mark: test/aoj/jag/dynamic_union_find.test.cpp

Depends on

Code

// competitive-verifier: PROBLEM https://onlinejudge.u-aizu.ac.jp/problems/2995
#include "tree/dynamic_union_find.hpp"
#include <iostream>
#include <unordered_map>
#include <utility>
#include <vector>
#include "graph/graph.hpp"
#include "tree/dsu_on_tree.hpp"

int main(void) {
    int n, k;
    std::cin >> n >> k;
    Graph<void> g(n);
    g.input_edges(n - 1);
    dsu_on_tree dsu(g);
    std::vector<std::pair<int, int>> a(n);
    for (auto &[x, y] : a) std::cin >> x >> y, --x, --y;
    std::vector<int> ans(n);
    int sum = 0;
    dynamic_union_find duf;
    std::unordered_map<int, bool> flag;
    auto rem = [&](int x) { ans[x] = sum; };
    auto clear = [&]() {
        sum = 0;
        duf.clear();
        flag.clear();
    };
    auto f = [&](int x, int y) {
        if (x == y) {
            if (!flag[x]) {
                ++sum;
                flag[x] = true;
            }
        } else {
            if (!flag[x] || !flag[y]) ++sum;
            flag[x] |= flag[y];
        }
    };
    auto query = [&](int v) {
        auto [s, t] = a[v];
        duf.unite(s, t, f);
    };
    dsu.solve(rem, clear, query);
    for (int i = 0; i < n; ++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/dynamic_union_find.hpp: line -1: no such header

Test cases

Env Name Status Elapsed Memory
g++ 00_sample_00 :heavy_check_mark: AC 2 ms 4 MB
g++ 00_sample_01 :heavy_check_mark: AC 2 ms 4 MB
g++ 00_sample_02 :heavy_check_mark: AC 2 ms 4 MB
g++ 01_small_01 :heavy_check_mark: AC 2 ms 4 MB
g++ 01_small_02 :heavy_check_mark: AC 2 ms 4 MB
g++ 02_mid_01 :heavy_check_mark: AC 5 ms 4 MB
g++ 02_mid_02 :heavy_check_mark: AC 5 ms 4 MB
g++ 03_large_01 :heavy_check_mark: AC 364 ms 15 MB
g++ 03_large_02 :heavy_check_mark: AC 604 ms 22 MB
g++ 04_max_01 :heavy_check_mark: AC 635 ms 16 MB
g++ 04_max_02 :heavy_check_mark: AC 594 ms 18 MB
g++ 05_line_01 :heavy_check_mark: AC 179 ms 48 MB
g++ 05_line_02 :heavy_check_mark: AC 212 ms 39 MB
g++ 06_uni_01 :heavy_check_mark: AC 149 ms 22 MB
g++ 06_uni_02 :heavy_check_mark: AC 117 ms 14 MB
g++ 07_mukade_01 :heavy_check_mark: AC 1048 ms 23 MB
g++ 07_mukade_02 :heavy_check_mark: AC 418 ms 16 MB
g++ 08_long_01 :heavy_check_mark: AC 173 ms 29 MB
g++ 08_long_02 :heavy_check_mark: AC 501 ms 30 MB
g++ 09_binary_01 :heavy_check_mark: AC 1221 ms 19 MB
g++ 09_binary_02 :heavy_check_mark: AC 936 ms 19 MB
g++ 10_knary_01 :heavy_check_mark: AC 209 ms 23 MB
g++ 10_knary_02 :heavy_check_mark: AC 194 ms 16 MB
g++ 11_one_01 :heavy_check_mark: AC 141 ms 23 MB
g++ 11_one_02 :heavy_check_mark: AC 183 ms 34 MB
g++ 11_one_03 :heavy_check_mark: AC 1209 ms 22 MB
g++ 11_one_04 :heavy_check_mark: AC 179 ms 14 MB
g++ 11_one_05 :heavy_check_mark: AC 870 ms 23 MB
g++ 11_one_06 :heavy_check_mark: AC 200 ms 53 MB
g++ 11_one_07 :heavy_check_mark: AC 143 ms 22 MB
g++ 11_one_08 :heavy_check_mark: AC 142 ms 26 MB
g++ 11_one_09 :heavy_check_mark: AC 689 ms 23 MB
g++ 11_one_10 :heavy_check_mark: AC 403 ms 22 MB
g++ 11_one_11 :heavy_check_mark: AC 566 ms 19 MB
g++ 11_one_12 :heavy_check_mark: AC 149 ms 44 MB
g++ 11_one_13 :heavy_check_mark: AC 143 ms 23 MB
g++ 11_one_14 :heavy_check_mark: AC 185 ms 34 MB
g++ 11_one_15 :heavy_check_mark: AC 1231 ms 20 MB
g++ 11_one_16 :heavy_check_mark: AC 180 ms 14 MB
g++ 12_few_01 :heavy_check_mark: AC 717 ms 19 MB
g++ 12_few_02 :heavy_check_mark: AC 189 ms 49 MB
g++ 12_few_03 :heavy_check_mark: AC 122 ms 17 MB
g++ 12_few_04 :heavy_check_mark: AC 165 ms 29 MB
g++ 12_few_05 :heavy_check_mark: AC 1228 ms 22 MB
g++ 12_few_06 :heavy_check_mark: AC 772 ms 20 MB
g++ 13_some_01 :heavy_check_mark: AC 691 ms 19 MB
g++ 13_some_02 :heavy_check_mark: AC 199 ms 50 MB
g++ 13_some_03 :heavy_check_mark: AC 138 ms 19 MB
g++ 13_some_04 :heavy_check_mark: AC 193 ms 35 MB
g++ 13_some_05 :heavy_check_mark: AC 829 ms 20 MB
g++ 13_some_06 :heavy_check_mark: AC 1124 ms 19 MB
g++ 14_many_01 :heavy_check_mark: AC 568 ms 22 MB
g++ 14_many_02 :heavy_check_mark: AC 202 ms 53 MB
g++ 14_many_03 :heavy_check_mark: AC 139 ms 22 MB
g++ 14_many_04 :heavy_check_mark: AC 193 ms 35 MB
g++ 14_many_05 :heavy_check_mark: AC 1224 ms 20 MB
g++ 14_many_06 :heavy_check_mark: AC 759 ms 22 MB
Back to top page