Submission #723590

#TimeUsernameProblemLanguageResultExecution timeMemory
723590drdilyorMagic Tree (CEOI19_magictree)C++17
22 / 100
467 ms1048576 KiB
#include<bits/stdc++.h> using namespace std; using ll = long long; int main() { int n, m, k; cin >> n >> m >> k; vector<vector<int>> child(n); vector par(n, -1); for (int i = 1; i < n; i++) { cin >> par[i]; child[--par[i]].push_back(i); } vector<pair<int,int>> fruit(n); for (int i =0; i < m;i ++) { int v, d, w; cin >> v >> d >> w; v--; fruit[v] = {d, w}; } vector memo(n, vector(k+1, -1)); auto dp = [&](auto& dp, int i, int day)->ll{ if (day == 0) return 0; if (memo[i][day] !=-1) return memo[i][day]; ll res1 = 0ll; if (fruit[i].first == day) res1 += fruit[i].second; for (int e : child[i]) { res1 += dp(dp, e, day); } return memo[i][day] = max(res1, dp(dp, i, day-1)); }; cout << dp(dp, 0, k) << '\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...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...