Pagini recente » Cod sursa (job #366312) | Cod sursa (job #1242391) | Cod sursa (job #167850) | Cod sursa (job #2057684) | Cod sursa (job #1409951)
#include <cstdio>
using namespace std;
long long int v[5000001],de[5000001];
int main(){
long long int n,st,dr,sum,i,k;
freopen("deque.in", "r", stdin);
freopen("deque.out", "w", stdout);
scanf("%lld %lld",&n,&k);
for(i = 1;i <= n;i++){
scanf("%lld",&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]];
}
}
printf("%lld\n",sum);
return 0;
}