제출 #723583

#제출 시각아이디문제언어결과실행 시간메모리
723583drdilyorMagic Tree (CEOI19_magictree)C++17
22 / 100
463 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<vector<pair<int,ll>>> fruit(n); for (int i = 0; i < m; i++) { int v, d, w; cin >> v >> d >> w; fruit[v-1].push_back({d, w}); } for (int i = 0; i < m; i++) { sort(fruit[i].begin(), fruit[i].end()); for (int j = 1; j < (int)fruit[i].size(); j++) { fruit[i][j].second += fruit[i][j-1].second; } } auto chop = [&](int i, int day)->ll{ auto ub = lower_bound(fruit[i].begin(), fruit[i].end(), pair{day+1, -1ll}); auto lb = lower_bound(fruit[i].begin(), fruit[i].end(), pair{day, -1ll}); if (ub == fruit[i].begin()) return 0; ub--; if (lb == fruit[i].begin()) return ub->second; return ub->second - (lb-1)->second; }; 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 = chop(i, day); 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...