Pagini recente » Cod sursa (job #500853) | Cod sursa (job #1641639) | Cod sursa (job #1155461) | Cod sursa (job #1325329) | Cod sursa (job #332189)
Cod sursa(job #332189)
#include <iostream>
long v[5000001],dq[5000001],i,n,k,beg,end;
long long sum;
using namespace std;
int main(){
freopen ("deque.in", "r", stdin);
scanf("%ld %ld", &n, &k);
for (i=1; i<=n; i++){
scanf("%ld" , &v[i]);
}
fclose(stdin);
beg=1;
end=0;
for (i=1; i<=n; i++){
while (beg<=end && v[dq[end]]>=v[i]){
--end;
}
end++;
dq[end]=i;
if (dq[beg]==i-k) beg++;
if (i>=k){
sum+=v[dq[beg]];
}
}
freopen ("deque.out", "w", stdout);
printf("%lld", sum);
fclose(stdout);
return 0;
}