Cod sursa(job #1907520)

Utilizator usureluflorianUsurelu Florian-Robert usureluflorian Data 6 martie 2017 19:41:15
Problema Secventa Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.82 kb
#include <fstream>
#include <deque>
using namespace std;
ifstream f ("secventa.in");
ofstream g ("secventa.out");
int v[5000001],s,i,n,k,mare=-10000000,st,dr,dist;
deque <int> d;
int main()
{
    f>>n>>k;
    for(i=1;i<=n;++i) f>>v[i];
    for(i=1;i<=n;++i)
    {
        while(!d.empty()&&v[i]<=v[d[d.size()-1]]) d.pop_back();
        d.push_back(i);
        if(d[0]==i-k) d.pop_front();
        if(i>=k)
        {
            if(v[d[0]]>mare)
            {
                mare=v[d[0]];
                dist=i-d[0]+1;
                st=d[0];
                dr=i;
            }
            else if(v[d[0]]==mare&&i-d[0]+1>dist)
            {
                dist=i-d[0]+1;
                st=d[0];
                dr=i;
            }
        }
    }
    g<<st<<' '<<dr<<' '<<mare;
    return 0;
}