This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
using namespace std;
#define ll long long
struct node{
int s, e, m, mini, tail, lazytail;
bool removed;
node *l, *r;
node(int S, int E){
s = S;
e = E;
m = (s+e)/2;
if(s == 0){
mini = 0;
}
else{
mini = INT_MAX;
}
tail = -1;
removed = 0;
lazytail = 0;
if(s != e){
l = new node(s, m);
r = new node(m+1, e);
}
}
void propagate(){
if(removed){
removed = 0;
mini = INT_MAX;
tail = INT_MIN;
if(s != e){
l->removed = 1;
r->removed = 1;
}
}
if(lazytail){
tail += lazytail;
if(s != e){
l->lazytail += lazytail;
r->lazytail += lazytail;
}
lazytail = 0;
}
}
void addtail(int S){
propagate();
if(e < S) return;
if(s >= S){
lazytail++;
return;
}
l->addtail(S);
r->addtail(S);
}
void remove(int E){
propagate();
if(s > E) return;
if(s && e <= E){
removed = 1;
return;
}
if(s != e){
l->remove(E);
r->remove(E);
}
}
void updatemini(int idx, int val, int newtail){
propagate();
if(s > idx || e < idx) return;
if(s == idx && e == idx){
mini = min(mini, val);
tail = newtail;
return;
}
l->updatemini(idx, val, newtail);
r->updatemini(idx, val, newtail);
mini = min(l->mini, r->mini);
}
pair<int, int> walk(int val){
propagate();
if(s == e) return {s, tail};
if(r->mini < val) return r->walk(val);
return l->walk(val);
}
//range update tail from x-end, tail += 1
//range update mini from 1-x, set mini = INT_MAX
//range update tail from 1-x, set tail = INT_MIN
//point update mini at x, set mini = val
//binary search for position of min val
} *root;
int main(){
ios_base::sync_with_stdio(0);
cin.tie(0);
int n, d, x;
pair<int, int> data;
cin>>n>>d;
root = new node(0, n);
vector<pair<int, int> > v(n, {0, 0});
for(int i=0; i<n; i++){
cin>>x;
data = root->walk(x); //{idx, tail}
if(i - data.second > d){
//need to invalidate idx and all below it
root->remove(data.first);
root->updatemini(1, x, i);
root->addtail(1);
}
else{
root->updatemini(data.first + 1, x, i-1);
root->addtail(data.first + 1);
}
}
data = root->walk(INT_MAX-1);
cout<<data.first;
return 0;
}
# | 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... |