제출 #448466

#제출 시각아이디문제언어결과실행 시간메모리
448466nickyrioFinancial Report (JOI21_financial)C++17
5 / 100
373 ms14464 KiB
#include <bits/stdc++.h> using namespace std; const int N = 3e5 + 100; int a[N], f[N], IT[N << 2], perm[N], kount[N], rightMost[N], leftMost[N]; void Update(int k, int l, int r, int u, int v) { if (l == r) { IT[k] = v; return; } int m = l + r >> 1; if (u <= m) Update(k << 1, l, m, u, v); else Update(k << 1 | 1, m + 1, r, u, v); IT[k] = max(IT[k << 1], IT[k << 1 | 1]); } int Query(int k, int l, int r, int u, int v) { if (l > v || r < u) return 0; if (u <= l && r <= v) return IT[k]; int m = (l + r) >> 1; return max(Query(k << 1, l, m, u, v), Query(k << 1 | 1, m + 1, r, u, v)); } int root(int u) { return (kount[u] < 0 ? u : kount[u] = root(kount[u])); } void Union(int u, int v) { // cerr << "Union" << u << ' ' << v << '\n'; u = root(u), v = root(v); if (u == v) return; int t = kount[u] + kount[v]; if (kount[u] > kount[v]) swap(u, v); kount[u] = t; kount[v] = u; rightMost[u] = max(rightMost[u], rightMost[v]); } int main() { int n, d; cin >> n >> d; int ans = 0; for (int i = 1; i <= n; ++i) { cin >> a[i]; perm[i] = i; } sort(perm + 1, perm + n + 1, [](int x, int y) { return a[x] != a[y] ? a[x] < a[y] : x > y; }); vector<int> obtacles; obtacles.push_back(0); for (int i = 1; i <= n; ++i) kount[i] = -1, rightMost[i] = i; for (int i = n; i > 0; --i) { int id = perm[i]; leftMost[id] = obtacles[lower_bound(obtacles.begin(), obtacles.end(), id) - obtacles.begin() - 1] + 1; // cerr << "ID = " << id << ' ' << leftMost[id] << '\n'; if (id > 1 && a[id - 1] >= a[id]) Union(id - 1, id); if (id != n && a[id + 1] > a[id]) Union(id, id + 1); int r = root(id); if (-kount[r] >= d) { // cerr << "Enough D " << id << ' ' << -kount[r] << ' ' << rightMost[r] << '\n'; obtacles.push_back(rightMost[r]); } } for (int i = 1; i <= n; ++i) { int id = perm[i]; int f = Query(1, 1, n, leftMost[id], id) + 1; ans = max(ans, f); Update(1, 1, n, id, f); } cout << ans << '\n'; }

컴파일 시 표준 에러 (stderr) 메시지

Main.cpp: In function 'void Update(int, int, int, int, int)':
Main.cpp:11:15: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
   11 |     int m = l + r >> 1;
      |             ~~^~~
#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...