Cod sursa(job #2636137)

Utilizator sireanu_vladSireanu Vlad sireanu_vlad Data 16 iulie 2020 18:41:45
Problema Secventa Scor 60
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.86 kb
#include <iostream>
#include <fstream>
#include <deque>
using namespace std;

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

int main()
{
    int n, k;
    in >> n >> k;
    int v[n];
    deque<int> u;
    int maxBaza = -30001, index = k;

    for(int i = 0; i < k; i++)
    {
        in >> v[i];
        while(!u.empty() && v[u.back()] >= v[i])
            u.pop_back();
        u.push_back(i);
    }

    for(int i = k; i < n; i++)
    {
        in >> v[i];
        while(!u.empty() && v[u.back()] >= v[i])
            u.pop_back();
        u.push_back(i);

        if(u.front() <= i - k)
            u.pop_front();

        if(v[u.front()] > maxBaza)
        {
            maxBaza = v[u.front()];
            index = i;
        }
    }

    out << index - k + 2 << " " << index + 1 << " " << maxBaza;

    return 0;
}