Cod sursa(job #1784581)

Utilizator teo.cons98Constantin Teodor-Claudiu teo.cons98 Data 20 octombrie 2016 11:18:18
Problema Deque Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.65 kb
#include<iostream>
#include<fstream>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
int n,k,p = 1,u = 0, j;
long long suma = 0;
int v[5000005],coada[5000005],pozmin;
int main()
{
    fin>>n>>k;
    for(int i = 1; i <= n; ++i)
    {
        fin>>v[i];
    }

    for(int i = 1;i <= n; ++i)
    {
        if(coada[p] == i-k)
        {
            p++;
        }
        j = u;
        while(v[coada[j]] > v[i] and j >= p)
        {
            j--;
        }
        coada[j+1] = i;
        u = j + 1;
        if(i >= k)
        {
            suma += v[coada[p]];
        }
    }
    fout<<suma;
}