Submission #1161370

#TimeUsernameProblemLanguageResultExecution timeMemory
1161370PikachudoraEHEGlobal Warming (CEOI18_glo)C++20
0 / 100
381 ms327680 KiB
#include<bits/stdc++.h>
using namespace std;
const int N =2e5+5;
vector<int>a(N),mem,mem2;
vector<int>memreal[N];
map<int,int>m;
int main(){
    ios_base::sync_with_stdio(0);cin.tie(0);
    int n,x;cin>>n>>x;
    for(int i=1;i<=n;i++){
        cin>>a[i];
        auto itr = upper_bound(mem.begin(),mem.end(),a[i]-x);
        if(itr==mem.end()){
            mem.push_back(a[i]-x);
        }
        else{
            *(itr)=a[i]-x;
        }
        memreal[i]=mem;
    }
    int ans = mem.size();
    for(int i=n;i>=1;i--){
        auto itr = upper_bound(mem2.begin(),mem2.end(),-a[i]);
        if(itr==mem2.end()){
            mem2.push_back(-a[i]);
            //mem22,push_back(a[i]);
        }
        else{
            *(itr)=-a[i];
            //mem22[itr-mem2.begin()]=a[i];
        }
        int cnt = 1;
        for(int j=0;j<memreal[i].size();j++){
            auto itr = lower_bound(mem2.begin(),mem2.end(),-memreal[i][j]);
            int idx = itr-mem2.begin();
            ans=max(ans,idx+j+1);
        }
    }
    cout<<ans;
return 0;
}
/*
9 110
7 3 5 6 12 2 7 3 4
*/
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...