Submission #659412

#TimeUsernameProblemLanguageResultExecution timeMemory
659412mychecksedadMagic Tree (CEOI19_magictree)C++17
34 / 100
91 ms59176 KiB
/* Author : Mychecksdead */ #include<bits/stdc++.h> #include <ext/pb_ds/tree_policy.hpp> using namespace __gnu_pbds; using namespace std; typedef long long int ll; typedef long double ld; #define MOD1 (1000000000+7) #define MOD (998244353) #define PI 3.1415926535 #define pb push_back #define setp() cout << setprecision(15) #define all(x) x.begin(), x.end() #define debug(x) cerr << #x << " is " << x << '\n'; const int N = 1e6+100, M = 1e5+10, F = 2147483646, K = 25; int n, m, k, t[N]; vector<int> g[N]; ll w[N], dp[N][K]; void dfs(int v, int p){ for(int i = 0; i < K; ++i) dp[v][i] = 0; for(int u: g[v]){ dfs(u, v); for(int i = 1; i < K; ++i) dp[v][i] += dp[u][i]; } dp[v][t[v]] += w[v]; for(int i = 1; i < K; ++i) dp[v][i] = max(dp[v][i], dp[v][i - 1]); } void solve(){ cin >> n >> m >> k; for(int i = 2; i <= n; ++i){ int p; cin >> p; g[p].pb(i); } for(int i = 0; i <= n; ++i) t[i] = w[i] = 0; for(int i = 0; i < m; ++i){ int v, d, e; cin >> v >> d >> e; t[v] = d; w[v] = e; } dfs(1, 0); cout << *max_element(dp[1] + 1, dp[1] + K); } int main(){ cin.tie(0); ios::sync_with_stdio(0); int T = 1, aa; // cin >> T;aa=T; while(T--){ // cout << "Case #" << aa-T << ": "; solve(); cout << '\n'; } return 0; }

Compilation message (stderr)

magictree.cpp: In function 'int main()':
magictree.cpp:60:16: warning: unused variable 'aa' [-Wunused-variable]
   60 |     int T = 1, aa;
      |                ^~
#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...