Submission #493581

#TimeUsernameProblemLanguageResultExecution timeMemory
493581600MihneaFinancial Report (JOI21_financial)C++17
48 / 100
4078 ms31080 KiB
#include <bits/stdc++.h> using namespace std; typedef long long ll; const int N = 300000 + 7; int n; int d; int a[N]; int dp[N]; int order[N]; bool cmp(int i, int j) { if (a[i] != a[j]) { return a[i] > a[j]; } else { return i < j; } } struct Node { int nothing = 0; int pref = 0; int suf = 0; int l; int r; int last = 0; }; Node none; Node operator + (Node a, Node b) { if (a.nothing) return b; if (b.nothing) return a; if (a.r + 1 != b.l) { cout << ": " << a.l << " " << a.r << " <-> " << b.l << " " << b.r << "\n"; exit(0); } assert(a.r + 1 == b.l); int pref = a.pref + b.pref * (a.pref == a.r - a.l + 1); int suf = b.suf + a.suf * (b.suf == b.r - b.l + 1); int l = a.l; int r = b.r; int last = 0; if (a.last) { last = a.last; } else { if (a.suf + b.pref >= d) { last = (a.r - a.suf + 1) + d - 1; } else { last = b.last; } } a.nothing = 0; a.pref = pref; a.suf = suf; a.l = l; a.r = r; a.last = last; return a; } Node tree[4 * N]; void build(int v, int tl, int tr) { tree[v].l = tl; tree[v].r = tr; if (tl < tr) { int tm = (tl + tr) / 2; build(2 * v, tl, tm); build(2 * v + 1, tm + 1, tr); } } void setup(int v, int tl, int tr, int i) { if (tr < i || i < tl) { return; } if (tl == tr) { tree[v].suf = tree[v].pref = 1; } else { int tm = (tl + tr) / 2; setup(2 * v, tl, tm, i); setup(2 * v + 1, tm + 1, tr, i); tree[v] = tree[2 * v] + tree[2 * v + 1]; } } Node get(int v, int tl, int tr, int l, int r) { if (tr < l || r < tl) return none; if (l <= tl && tr <= r) { return tree[v]; } int tm = (tl + tr) / 2; Node ff = get(2 * v, tl, tm, l, r); Node ss = get(2 * v + 1, tm + 1, tr, l, r); return ff + ss; } bool deja[N]; signed main() { none.nothing = 1; ios::sync_with_stdio(0); cin.tie(0); /// freopen ("TonyStark", "r", stdin); cin >> n >> d; for (int i = 1; i <= n; i++) { cin >> a[i]; order[i] = i; } build(1, 1, n); sort(order + 1, order + n + 1, cmp); for (int it = 1; it <= n; it++) { int i = order[it]; deja[i] = 1; dp[i] = 0; int bigger = 0; int mylast = get(1, 1, n, i + 1, n).last; setup(1, 1, n, i); if (!mylast) { mylast = n; } int last = i; for (int j = i + 1; j <= n; j++) { dp[i] = max(dp[i], dp[j]); last = j; if (deja[j]) { bigger++; } else { bigger = 0; } if (bigger == d) { break; } } assert(last == mylast); ///cout << i << " : " << mylast << " vs " << last << "\n"; dp[i]++; } int sol = 0; for (int i = 1; i <= n; i++) { sol = max(sol, dp[i]); } cout << sol << "\n"; }
#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...