cp-library

This documentation is automatically generated by online-judge-tools/verification-helper

View the Project on GitHub rniya/cp-library

:heavy_check_mark: test/yosupo/frequency_table_of_tree_distance.test.cpp

Depends on

Code

#define PROBLEM "https://judge.yosupo.jp/problem/frequency_table_of_tree_distance"

#include <iostream>
#include "atcoder/convolution"
#include "tree/CentroidDecomposition.hpp"

int main() {
    std::cin.tie(0);
    std::ios::sync_with_stdio(false);
    int N;
    std::cin >> N;
    CentroidDecomposition CD(N);
    for (int i = 0; i < N - 1; i++) {
        int a, b;
        std::cin >> a >> b;
        CD.add_edge(a, b);
    }

    std::vector<int> alive(N, true);
    auto& G = CD.G;
    auto calc = [&](auto self, int v, int p, int d, std::vector<long long>& cnt) -> void {
        while ((int)cnt.size() <= d) cnt.emplace_back(0);
        cnt[d]++;
        for (int& u : G[v]) {
            if (u == p || !alive[u]) continue;
            self(self, u, v, d + 1, cnt);
        }
    };

    auto cs = CD.build();
    std::vector<long long> ans(2 * N, 0);

    for (int& root : cs) {
        alive[root] = 0;
        std::vector<long long> sum{1};
        for (int& ch : G[root]) {
            if (!alive[ch]) continue;
            std::vector<long long> cnt;
            calc(calc, ch, root, 1, cnt);
            auto sub = atcoder::convolution_ll(cnt, cnt);
            for (size_t i = 0; i < sub.size(); i++) ans[i] -= sub[i];
            while (sum.size() < cnt.size()) sum.emplace_back(0);
            for (size_t i = 0; i < cnt.size(); i++) sum[i] += cnt[i];
        }
        auto add = atcoder::convolution_ll(sum, sum);
        for (size_t i = 0; i < add.size(); i++) ans[i] += add[i];
    }

    for (int i = 1; i < N; i++) std::cout << ans[i] / 2 << (i + 1 == N ? '\n' : ' ');
}
Traceback (most recent call last):
  File "/opt/hostedtoolcache/Python/3.13.3/x64/lib/python3.13/site-packages/onlinejudge_verify/documentation/build.py", line 71, in _render_source_code_stat
    bundled_code = language.bundle(stat.path, basedir=basedir, options={'include_paths': [basedir]}).decode()
                   ~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/opt/hostedtoolcache/Python/3.13.3/x64/lib/python3.13/site-packages/onlinejudge_verify/languages/cplusplus.py", line 187, in bundle
    bundler.update(path)
    ~~~~~~~~~~~~~~^^^^^^
  File "/opt/hostedtoolcache/Python/3.13.3/x64/lib/python3.13/site-packages/onlinejudge_verify/languages/cplusplus_bundle.py", line 401, in update
    self.update(self._resolve(pathlib.Path(included), included_from=path))
                ~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/opt/hostedtoolcache/Python/3.13.3/x64/lib/python3.13/site-packages/onlinejudge_verify/languages/cplusplus_bundle.py", line 260, in _resolve
    raise BundleErrorAt(path, -1, "no such header")
onlinejudge_verify.languages.cplusplus_bundle.BundleErrorAt: atcoder/convolution: line -1: no such header
Back to top page