Cod sursa(job #1414774)

Utilizator avaspAva Spataru avasp Data 2 aprilie 2015 23:53:07
Problema Secventa Scor 80
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.85 kb
#include<cstdio>
#include<deque>
using namespace std;
int v[500001],n,k,ad,ci,cs,mini;
deque<int>D;
int main(){
    freopen("secventa.in","r",stdin);
    freopen("secventa.out","w",stdout);
    scanf("%d%d",&n,&k);
    for(int i=1;i<=n;i++)
        scanf("%d",&v[i]);
    for(int i=1;i<=k;i++){
        ad=i;
        while(!D.empty()&&v[D.back()]>v[ad])
            D.pop_back();
        D.push_back(ad);
    }
    mini=v[D.front()];
    ci=1;
    cs=k;
    for(int i=2;i<=n-k+1;i++){
        while(!D.empty()&&D.front()<i)
            D.pop_front();
        ad=i+k-1;
        while(!D.empty()&&v[D.back()]>v[ad])
            D.pop_back();
        D.push_back(ad);
        if(v[D.front()]>mini){
            mini=v[D.front()];
            ci=i;
            cs=i+k-1;
        }
    }
    printf("%d %d %d",ci,cs,mini);
    return 0;
}