/ SeriousOJ /

Record Detail

Time Exceeded


  
# Status Time Cost Memory Cost
#1 Accepted 1ms 532.0 KiB
#2 Accepted 4ms 532.0 KiB
#3 Accepted 83ms 572.0 KiB
#4 Accepted 62ms 604.0 KiB
#5 Accepted 77ms 608.0 KiB
#6 Accepted 89ms 836.0 KiB
#7 Accepted 107ms 1.02 MiB
#8 Accepted 133ms 2.785 MiB
#9 Accepted 138ms 2.812 MiB
#10 Accepted 139ms 3.672 MiB
#11 Time Exceeded ≥2001ms ≥14.406 MiB
#12 Time Exceeded ≥2100ms ≥34.141 MiB

Code

#include <bits/stdc++.h>

using i64 = long long;

using B = std::bitset<100000>;

void solve() {
    int n;
    std::cin >> n;
    std::vector<int> a(n);
    for (int i = 0; i < n; i++) {
        std::cin >> a[i];
        a[i]--;
    }
    std::vector<std::vector<int>> g(n);
    std::vector<int> size(n);
    for (int i = 0; i < n - 1; i++) {
        int u, v;
        std::cin >> u >> v;
        u--;
        v--;
        g[u].push_back(v);
        g[v].push_back(u);
    }
    std::vector<int> hson(n);
    auto build = [&](auto&& self, int v, int fa) -> int {
        int sz = 1, hsz = 0, hs = -1;
        for (auto w : g[v]) {
            if (w != fa) {
                int s = self(self, w, v);
                sz += s;
                if (s > hsz) {
                    hsz = s;
                    hs = w;
                }
            }
        }
        hson[v] = hs;
        size[v] = sz;
        return sz;
    };
    build(build, 0, -1);

    std::vector<int> ans(n);
    auto f = [&](auto&& self, int v, int fa) -> std::unordered_set<int> {
        if (hson[v] < 0) {
            if (a[v] != 0) {
                ans[v] = 1;
            }
            return std::unordered_set<int>{a[v]};
        }
        std::unordered_set<int> has = self(self, hson[v], v);
        for (auto w : g[v]) {
            if (w != fa && w != hson[v]) {
                std::unordered_set<int> subM = self(self, w, v);
                for (auto key : subM) {
                    has.insert(key);
                }
            }
        }
        has.insert(a[v]);
        ans[v] = size[v];
        for (auto key : has) {
            if (key >= size[v]) {
                continue;
            }
            ans[v]--;
        }
        return has;
    };

    f(f, 0, -1);
    int q;
    std::cin >> q;
    while (q--) {
        int x;
        std::cin >> x;
        x--;
        std::cout << ans[x] << "\n";
    }

}

int main() {
    std::ios::sync_with_stdio(false);
    std::cin.tie(nullptr);
    std::cout.tie(nullptr);

    int t;
    std::cin >> t;
    while (t--) {
        solve();
    }
}

Information

Submit By
Type
Submission
Problem
P1157 Roy and Tree Permutation
Contest
Happy New Year 2025
Language
C++17 (G++ 13.2.0)
Submit At
2025-01-02 15:30:43
Judged At
2025-01-02 15:30:43
Judged By
Score
50
Total Time
≥2100ms
Peak Memory
≥34.141 MiB