Cod sursa(job #2366955)

Utilizator FrostfireMagirescu Tudor Frostfire Data 4 martie 2019 23:20:12
Problema Secventa Scor 0
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.67 kb
#include <fstream>
#include <iostream>

using namespace std;

ifstream f("secventa.in");
ofstream g("secventa.out");

int n, k, v[500100], Deque[500100], sol = -50000, st, dr, p1, p2;

int main()
{
    f >> n >> k;
    for(int i=1; i<=n; i++) f >> v[i];
    st = 1;
    dr = 0;
    for(int i=1; i<=n; i++)
    {
        if(Deque[st] == i-k) st++;
        while(st <= dr && v[i] <= v[Deque[dr]]) dr--;
        Deque[++dr] = i;
        if(i >= k && v[Deque[st]] > sol)
        {
            sol = v[Deque[st]];
            p1 = Deque[st];
            p2 = Deque[st] + k - 1;
        }
    }
    g << p1 << ' ' << p2 << ' ' << sol << '\n';
    return 0;
}