Submission #486537

#TimeUsernameProblemLanguageResultExecution timeMemory
486537SamboorFireworks (APIO16_fireworks)C++17
26 / 100
1 ms332 KiB
// Grzegorz Ryn // V LO Kraków #include <bits/stdc++.h> using namespace std; typedef long long ll; #define pb push_back #define st first #define nd second const ll INF = 1'000'000'000; int N, M; vector<vector<int>> g; vector<ll> cost; vector<int> slope_ind; vector<vector<ll>> slope; vector<ll> initial_slope, final_slope, first_value; void dfs(int v) { if(v > N) { slope[v].pb(cost[v]); slope[v].pb(cost[v]); initial_slope[v] = -1; final_slope[v] = 1; first_value[v] = cost[v]; return; } for(int u:g[v]) { dfs(u); int V = slope_ind[v]; int U = slope_ind[u]; if(slope[V].size() < slope[U].size()) { swap(V, U); swap(slope_ind[v], slope_ind[u]); } for(int p : slope[U]) { slope[V].pb(p); } sort(slope[V].begin(), slope[V].end()); first_value[v] += first_value[u]; initial_slope[v] += initial_slope[u]; final_slope[v] += final_slope[u]; } int V = slope_ind[v], l, r; while(final_slope[v] >= 0) { assert(slope[V].size() > 0); if(final_slope[v] == 1) { r = slope[V].back(); } else if(final_slope[v] == 0) { l = slope[V].back(); } slope[V].pop_back(); final_slope[v]--; } first_value[v] += cost[v]; slope[V].pb(l + cost[v]); slope[V].pb(r + cost[v]); final_slope[v] = 1; } int main() { ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); cin >> N >> M; g.resize(N+M+1); cost.resize(N+M+1, 0); slope.resize(N+M+1); slope_ind.resize(N+M+1); iota(slope_ind.begin(), slope_ind.end(), 0); initial_slope.resize(N+M+1, 0); final_slope.resize(N+M+1, 0); first_value.resize(N+M+1, 0); for(int i=2; i<=N+M; i++) { int p; cin >> p >> cost[i]; g[p].pb(i); } dfs(1); int it = slope_ind[1]; ll result = (ll)INF*INF, res = first_value[1], prv = 0; for(ll pos : slope[it]) { res += initial_slope[1] * (pos - prv); initial_slope[1]++; prv = pos; result = min(result, res); if(initial_slope[1] >= 0) { break; } } cout << result << '\n'; return 0; }

Compilation message (stderr)

fireworks.cpp: In function 'void dfs(int)':
fireworks.cpp:69:14: warning: 'r' may be used uninitialized in this function [-Wmaybe-uninitialized]
   69 |  slope[V].pb(r + cost[v]);
      |              ^
fireworks.cpp:68:14: warning: 'l' may be used uninitialized in this function [-Wmaybe-uninitialized]
   68 |  slope[V].pb(l + cost[v]);
      |              ^
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...