Cod sursa(job #1907840)

Utilizator aeromaniaXRadoi Iulian aeromaniaX Data 6 martie 2017 21:13:04
Problema Deque Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.76 kb
#include <bits/stdc++.h>
using namespace std;
struct meh
{
    int val,i;
}x;
deque <meh> q;
long long k,n,s;
int main()
{
    freopen("deque.in","r",stdin);
    freopen("deque.out","w",stdout);
    scanf("%lld%lld",&n,&k);

    for(int i=1;i<=k;i++)
    {
        scanf("%lld",&x.val);
        x.i=i;
        while(!q.empty() && q.back().val>=x.val) q.pop_back();
        q.push_back(x);

    }
    s=q.front().val;
    for(int i=k+1;i<=n;i++)
    {
        scanf("%d",&x.val);
        x.i=i;
        while(!q.empty() && q.back().val>=x.val) q.pop_back();
        q.push_back(x);

        if(q.front().i<i-k+1) q.pop_front();

        s=s+q.front().val;
       // printf("%d\n",q.front().val);
    }
    printf("%lld\n",s);
    return 0;

}