이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using namespace std;
#define int long long
const int mxN = 3e5 + 7;
const int SZ = exp2(ceil(log2(mxN)));
const int INF = 1e9 + 7;
int n, d, arr[mxN], seg[4*mxN], nex[mxN], dp[mxN];
void update(int ind, int val) {
seg[ind+=SZ] = val;
while (ind /= 2) {
seg[ind] = max(seg[2*ind], seg[2*ind+1]);
}
}
int query(int lo, int hi, int ind = 1, int l = 0, int r = SZ - 1) {
if (lo > r || l > hi) {
return -INF;
}
if (lo <= l && r <= hi) {
return seg[ind];
}
int mid = (l+r)/2;
return max(query(lo,hi,2*ind,l,mid), query(lo,hi,2*ind+1,mid+1,r));
}
int32_t main() {
ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0);
cin >> n >> d;
for (int i = 0; i < n; ++i) {
cin >> arr[i];
}
arr[n] = INT_MAX;
vector<int> st = {n};
for (int i = n-1; i >= 0; --i) {
while (st.size() && arr[st.back()] <= arr[i]) {
st.pop_back();
}
nex[i] = st.back();
st.push_back(i);
if (i < n-1) {
update(i, -INF);
}
}
update(n-1, 1);
update(n, -INF);
for (int i = n-2; i >= 0; --i) {
dp[i] = max(query(nex[i], min(n, nex[i]+d-1)) + 1,
(query(i, i+d) ? 1ll : -1ll));
update(i, (dp[i] < 0 ? -INF : dp[i]));
}
cout << query(0, n-1) << "\n";
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |