Cod sursa(job #1154632)

Utilizator Vally77FMI Calinescu Valentin Gelu Vally77 Data 26 martie 2014 11:49:11
Problema Secventa Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.03 kb
#include <iostream>
#include <fstream>
#include <deque>
using namespace std;
ifstream ka("secventa.in");
ofstream ki("secventa.out");
struct element
{
    int el, indice;
};
deque <element> coada;
int x, n, k, maxim = -100000, inc = 1, sf = 1;
string s;
int main()
{
    ka >> n >> k;
    getline(ka, s);
    for(int i = 0; i <s.size(); i++)
    {
        x = 1;
        if(s[i] == '-')
        {
            x *= -1;
            i++;
        }
        while(s[i]!= ' ')
            x = x*10 + s[i]- '0';
        while(!coada.empty() && coada.back().el > x)
        {
            coada.pop_back();
        }
        if(!coada.empty() && i - coada.front().indice + 1 > k)
            coada.pop_front();
        element elo;
        elo.el = x;
        elo.indice = i;
        coada.push_back(elo);
        if(coada.front().el > maxim && i >= k)
        {
            maxim = coada.front().el;
            inc = i-k+1;
            sf = i;
        }
        i--;
    }
    ki << inc << " " << sf << " " << maxim;
}