Submission #469036

#TimeUsernameProblemLanguageResultExecution timeMemory
469036paga2004Chase (CEOI17_chase)C++17
0 / 100
4062 ms12788 KiB
#include <bits/stdc++.h> #ifdef LOCAL #define dbg(x) cerr << "dgb: " << x << "\n"; #else #define dbg(x) #pragma GCC optimize("O3") #pragma GCC optimize("unroll-loops") #pragma GCC target("avx,avx2,tune=native") #endif using namespace std; int n; vector<int> c; vector<int> sum; vector<vector<int>> g; int f(int v, int p, int k, bool dropped) { if (k == 0) return 0; int maxi = 0; for (int w : g[v]) { if (w == p) continue; maxi = max(maxi, f(w, v, k - 1, true) + sum[v] - (dropped ? 0 : c[v])); maxi = max(maxi, f(w, v, k, false)); } return maxi; } signed main() { ios_base::sync_with_stdio(false); cin.tie(nullptr); int k; cin >> n >> k; c.resize(n); g.resize(n); sum.resize(n); for (int &x : c) cin >> x; for (int i = 0; i < n - 1; i++) { int a, b; cin >> a >> b; a--; b--; g[b].push_back(a); g[a].push_back(b); sum[a] += c[b]; sum[b] += c[a]; } int best = 0; for (int root = 0; root < n; root++) best = max(best, f(root, root, k, false)); cout << best << "\n"; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...