Submission #242277

#TimeUsernameProblemLanguageResultExecution timeMemory
242277dwscMagic Tree (CEOI19_magictree)C++14
0 / 100
2126 ms609692 KiB
#include <bits/stdc++.h> #define int long long using namespace std; int n,m,k; vector<int> adj[100010]; int ripe[100010]; int weight[100010]; int memo[100010][1010]; int dp(int u,int j){ if (memo[u][j] != -1) return memo[u][j]; int s1 = 0; for (int i = 0; i < adj[u].size(); i++){ int v = adj[u][i]; s1 += dp(v,j); } int s2 = 0; if (ripe[u] <= j) s2 = weight[u]; for (int i = 0; i < adj[u].size(); i++){ int v = adj[u][i]; s2 += dp(v,ripe[u]); } return memo[u][j] = max(s1,s2); } main(){ cin >> n >> m >> k; for (int i = 2; i <= n; i++){ int p; cin >> p; adj[p].push_back(i); } //vector<int> temp; //temp.push_back(0); for (int i = 0; i < m; i++){ int v,d,w; cin >> v >> d >> w; ripe[v] = d; weight[v] = w; //temp.push_back(d); } //sort(temp.begin(),temp.end()); //temp.erase(unique(temp.begin(),temp.end()),temp.end()); //for (int i = 1; i <= n; i++) ripe[i] = lower_bound(temp.begin(),temp.end(),ripe[i])-temp.begin(); //for (int i = 1; i <= n; i++) cout << ripe[i] << "\n"; for (int i = 1; i <= n; i++) for (int j = 0; j <= k; j++) memo[i][j] = -1; cout << dp(1,k); }

Compilation message (stderr)

magictree.cpp: In function 'long long int dp(long long int, long long int)':
magictree.cpp:12:23: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
     for (int i = 0; i < adj[u].size(); i++){
                     ~~^~~~~~~~~~~~~~~
magictree.cpp:18:23: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
     for (int i = 0; i < adj[u].size(); i++){
                     ~~^~~~~~~~~~~~~~~
magictree.cpp: At global scope:
magictree.cpp:24:6: warning: ISO C++ forbids declaration of 'main' with no type [-Wreturn-type]
 main(){
      ^
#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...