Cod sursa(job #678845)

Utilizator repp4raduRadu-Andrei Szasz repp4radu Data 12 februarie 2012 14:32:40
Problema Secventa Scor 90
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.74 kb
#include<cstdio>
#include<deque>

#define MAX 500050

using namespace std;

int v[MAX];
deque<int> DQ;

int main()
{
    freopen("secventa.in", "r", stdin);
    int n, k, end, sol = -30050;
    scanf("%d %d\n", &n, &k);
    for(int i = 1; i <= n; i++)
    {
        scanf("%d", &v[i]);
        while(!DQ.empty() && v[i] < v[DQ.back()])
            DQ.pop_back();
        DQ.push_back(i);
        if(DQ.front() == i - k)
        {
            DQ.pop_front();
        }
        if(i >= k && v[DQ.front()] > sol)
        {
            sol = v[DQ.front()];
            end = i;
        }
    }
    fclose(stdin);
    freopen("secventa.out", "w", stdout);
    printf("%d %d %d", end - k + 1, end, sol);
    fclose(stdout);
}