Cod sursa(job #1409965)

Utilizator alittlezzCazaciuc Valentin alittlezz Data 30 martie 2015 19:50:51
Problema Deque Scor 60
Compilator cpp Status done
Runda Arhiva educationala Marime 0.57 kb
#include <fstream>

using namespace std;

long long int v[5000001],de[5000001];

int main(){
    long long int n,st,dr,sum,i,k;
    ifstream f("deque.in");
    ofstream g("deque.out");
    f>>n>>k;
    for(i = 1;i <= n;i++){
        f>>v[i];
    }
    st = 0;
    dr = sum = 0;
    for(i = 1;i <= n;i++){
        while(st <= dr && v[i] <= v[de[dr]]){
            dr--;
        }
        de[++dr] = i;
        if(de[st] == i-k){
            st++;
        }
        if(i >= k){
            sum += v[de[st]];
        }
    }
    g<<sum;
    return 0;
}