Pagini recente » Cod sursa (job #807187) | Cod sursa (job #1256462) | Cod sursa (job #3245253) | Cod sursa (job #1641466) | Cod sursa (job #1604756)
#include <stdio.h>
#include <deque>
using namespace std;
deque <int> d;
int v[5000001];
int main()
{
freopen("deque.in","r",stdin);
freopen("deque.out","w",stdout);
int n, i, k;
long long s = 0;
scanf("%d%d",&n,&k);
for(i=1;i<=n;i++)
{
scanf("%d",&v[i]);
while(!d.empty() && v[d.back()]>=v[i]){
d.pop_back();
}
d.push_back(i);
if(i>=k) {
if(d.back()-d.front()+1 > k ) {
d.pop_front();
}
s += v[d.front()];
}
}
printf("%lld",s);
return 0;
}