Cod sursa(job #1557190)

Utilizator geni950814Geni Geni geni950814 Data 26 decembrie 2015 23:06:08
Problema Secventa Scor 80
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.62 kb
#include<fstream>
#include<queue>
 
#define MAX 500050
 
using namespace std;
 
int n, k,v[MAX], sol = -30050;
deque<int> DQ;
 
int main()
{
    ifstream in("secventa.in");
    ofstream out("secventa.out");
    int i, end;
    in>>n>>k;
    for(i = 1; i <= n; i++)
    {
        in>>v[i];
        while(!DQ.empty() && v[i] <= v[DQ.back()])
            DQ.pop_back();
        DQ.push_back(i);
        if(DQ.front() == i - k)
            DQ.pop_front();
        if(i >= k && v[DQ.front()] > sol)
        {
            sol = v[DQ.front()];
            end = i;
        }
    }
    out<<end - k + 1<<" "<<end<<" "<<sol;
    fclose(stdout);
}