Cod sursa(job #2046118)

Utilizator dragostanTantaru Dragos Constantin dragostan Data 23 octombrie 2017 14:43:40
Problema Secventa Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.74 kb
#include <fstream>

using namespace std;
ifstream cin("secventa.in");
ofstream cout("secventa.out");
const int DIM = 5000001;
int d[DIM], v[DIM];
int main()
{
    int n, k;
    cin >> n >> k;

    int st = 0, dr = -1, s = 0, maxi = -1, ind;
    for(int i = 0; i < n; ++i)
    {
        cin >> v[i];

        if(st <= dr && d[st] == i - k)
        {
            ++st;
        }
        while(st <= dr && v[i] > v[d[dr]])
        {
            s -= v[d[dr]];
            --dr;
        }
        d[++dr] = i;
        s += v[i];
        if(i >= k - 1)
            if(s > maxi)
            {
                maxi = s;
                ind = d[dr];
            }
    }

    for(int i = ind; i >= ind - k + 1; --i)
            cout << v[i] << ' ';
    return 0;
}