Submission #417627

#TimeUsernameProblemLanguageResultExecution timeMemory
417627maomao90Worst Reporter 4 (JOI21_worst_reporter4)C++17
79 / 100
406 ms524292 KiB
#include <bits/stdc++.h> using namespace std; template <class T> inline bool mnto(T& a, T b) {return a > b ? a = b, 1 : 0;} template <class T> inline bool mxto(T& a, T b) {return a < b ? a = b, 1: 0;} #define REP(i, s, e) for (int i = s; i < e; i++) #define RREP(i, s, e) for (int i = s; i >= e; i--) typedef long long ll; typedef long double ld; #define MP make_pair #define FI first #define SE second typedef pair<int, int> ii; typedef pair<ll, ll> pll; #define MT make_tuple typedef tuple<int, int, int> iii; #define ALL(_a) _a.begin(), _a.end() #define pb emplace_back typedef vector<int> vi; typedef vector<ll> vll; typedef vector<ii> vii; #define INF 1000000005 #define LINF 1000000000000000005 #define MOD 1000000007 #define MAXN 200005 int n; int h[MAXN], c[MAXN]; vi adj[MAXN]; map<int, ll> incre[MAXN]; ll ans; void dp(int u) { for (int v : adj[u]) { dp(v); if (incre[v].size() > incre[u].size()) swap(incre[v], incre[u]); for (auto i : incre[v]) { incre[u][i.FI] += i.SE; } } auto lower = incre[u].lower_bound(h[u]); if (lower != incre[u].begin()) { lower = prev(lower); int remc = c[u]; while (1) { //printf("%d %lld\n", lower -> FI, lower -> SE); ll take = min((ll) remc, lower -> SE); lower -> SE -= take; remc -= take; if (lower -> SE == 0) { auto tmp = lower; bool hv = 0; if (tmp != incre[u].begin()) { tmp = prev(tmp); hv = 1; } incre[u].erase(lower); if (!hv) { break; } else { lower = tmp; } } else { break; } } } incre[u][h[u]] += c[u]; //printf("%d:\n", u); //for (auto i : incre[u]) { //printf(" %d %lld\n", i.FI, i.SE); //} } int main() { scanf("%d", &n); REP (i, 1, n + 1) { int a; scanf("%d%d%d", &a, &h[i], &c[i]); ans += c[i]; if (a != i) adj[a].pb(i); } dp(1); for (auto i : incre[1]) { ans -= i.SE; } printf("%lld\n", ans); return 0; } /* 4 1 3 4 1 1 2 2 0 3 3 2 1 */

Compilation message (stderr)

worst_reporter2.cpp: In function 'int main()':
worst_reporter2.cpp:79:7: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   79 |  scanf("%d", &n);
      |  ~~~~~^~~~~~~~~~
worst_reporter2.cpp:81:15: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   81 |   int a; scanf("%d%d%d", &a, &h[i], &c[i]);
      |          ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...