Cod sursa(job #2938226)

Utilizator PostoacaMateiMatei Postoaca PostoacaMatei Data 11 noiembrie 2022 19:58:46
Problema Secventa Scor 10
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 1.11 kb
#include <bits/stdc++.h>

using namespace std;

ifstream fin("secventa.in");
ofstream fout("secventa.out");

int main()
{
    long long n,k,a[500001],baza=-30000,ifinal=0,jfinal=0;
    deque<int> d;
    fin>>n>>k;
    for(int i=1;i<=n;i++){
        fin>>a[i];
        while(!d.empty() && a[d.back()]>a[i])
            d.pop_back();
        if(!d.empty() && d.front()==i-k)
            d.pop_front();
        d.push_back(i);
        if(i>=k && baza<a[d.front()]){
            baza=a[d.front()];
            /*
            cout<<"!!CAZ <: \n";
            cout<<"baza: "<<baza<<"\n";
            cout<<"d.front(): "<<d.front()<<"\n";
            cout<<"i: "<<i<<"\n";
            cout<<"\n";
            */
            ifinal=i-k+1;
            jfinal=i;
        }
        else if(i>=k && baza==a[d.front()]){
            /*
            cout<<"!!CAZ ==: \n";
            cout<<"baza: "<<baza<<"\n";
            cout<<"i: "<<i<<"\n";
            cout<<"\n";
            */
            ifinal=i-k+1;
            jfinal=i;
        }
    }
    fout<<ifinal<<" "<<jfinal<<" "<<baza;
    return 0;
}