제출 #996989

#제출 시각아이디문제언어결과실행 시간메모리
996989siewjhJobs (BOI24_jobs)C++17
100 / 100
186 ms66756 KiB
#include <bits/stdc++.h> using namespace std; typedef long long ll; typedef priority_queue<pair<ll, ll>> pqii; const int MAXN = 300005; vector<int> adj[MAXN]; ll val[MAXN]; pqii dfs(int x){ pqii pq; for (int nn : adj[x]){ auto join = dfs(nn); if (pq.size() < join.size()) swap(pq, join); while (!join.empty()){ pq.push(join.top()); join.pop(); } } if (val[x] > 0) pq.push({0, val[x]}); else{ ll mp = val[x], sum = val[x]; while (!pq.empty()){ ll jmp, js; tie(jmp, js) = pq.top(); if (sum <= 0){ pq.pop(); mp = min(mp, sum + jmp); sum += js; } else{ if (jmp < mp) break; pq.pop(); sum += js; } } if (sum > 0) pq.push({mp, sum}); } return pq; } int main(){ ios_base::sync_with_stdio(false); cin.tie(0); cout.tie(0); int nums; cin >> nums >> val[0]; for (int i = 1; i <= nums; i++){ int par; cin >> val[i] >> par; adj[par].push_back(i); } auto pq = dfs(0); ll ans = 0; while (!pq.empty()){ ll mp, sum; tie(mp, sum) = pq.top(); pq.pop(); if (ans + mp >= 0) ans += sum; else break; } cout << ans - val[0]; }
#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...