Submission #1085629

#TimeUsernameProblemLanguageResultExecution timeMemory
1085629vjudge1Global Warming (CEOI18_glo)C++17
0 / 100
77 ms4808 KiB
#include <bits/stdc++.h>
using namespace std;
int main()
{
    int n,x,a;
    cin>>n>>x;
    vector<int>v,dp(n,INT_MAX),pref;
    for(int i=0;i<n;i++)
    {
        cin>>a;
        v.push_back(a);
    }
    int res=0;
    for(int i=0;i<n;i++)
    {
        int temp=lower_bound(dp.begin(),dp.end(),v[i])-dp.begin();
        pref.push_back(temp+1);
        dp[temp]=v[i];
        res=max(res,temp+1);
    }
    for(int i=n-1;i>=0;i--)
    {
        int temp=lower_bound(dp.begin(),dp.end(),v[i])-dp.begin();
        res=max(res,pref[i]+temp);
        temp=lower_bound(dp.begin(),dp.end(),v[i]+x)-dp.begin();
        dp[temp]=v[i]+x;
    }
    return 0;
}
#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...