Pagini recente » Cod sursa (job #1254217) | Cod sursa (job #2170333) | Cod sursa (job #10369) | Cod sursa (job #1416848) | Cod sursa (job #2164641)
#include<bits/stdc++.h>
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");
int N,K,v[5000001],s,Front,Back,Deque[5000001];
int main()
{
f>>N>>K;
for(int i=1;i<=N;++i)f>>v[i];
Front=1,Back=0;
for(int i=1;i<=N;++i){
while(Front<=Back&&v[i]<=v[Deque[Back]])--Back;
Deque[++Back]=i;
if(i-K==Deque[Front])++Front;
if(K<=i)s+=v[Deque[Front]];
}
g<<s;
return 0;
}