Cod sursa(job #2429397)

Utilizator rd211Dinucu David rd211 Data 9 iunie 2019 14:50:14
Problema Secventa Scor 80
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.79 kb
#include <fstream>
#include <deque>
using namespace std;
ifstream fin("secventa.in");
ofstream fout("secventa.out");
int A[5000010];
deque<pair<int,int>> Deque;
int n,k,maxim = -2000000000,start,val;
int main()
{
    fin>>n>>k;
    for(int i = 1; i<=n; i++)
        fin>>A[i];
    for(int i = 1; i<=n; i++)
    {
        val = A[i];
        while(Deque.size() && Deque.back().first >= val)
            Deque.pop_back();
        Deque.push_back({val,i});
        if(Deque.front().second<=i-k)
            Deque.pop_front();
        if(i>=k)
        {
            if(Deque.front().first>maxim)
            {
                maxim = Deque.front().first;
                start = i-k+1;
            }
        }
    }
    fout<<start<<' '<<start+k-1<<' '<<maxim;
    return 0;
}