제출 #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...