Pagini recente » Cod sursa (job #1158275) | Cod sursa (job #1861577) | Cod sursa (job #2121915) | Cod sursa (job #1092327) | Cod sursa (job #3126270)
#include <bits/stdc++.h>
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");
const int NMAX = 5e6 + 5;
long long a[NMAX], dq[NMAX], n, k, st = 1, dr;
int main(){
f >> n >> k;
for(int i = 1; i <= n; ++i){
f >> a[i];
}
long long sol = 0;
for(int i = 1; i <= n; ++i){
while(st <= dr && dq[st] < i - k + 1){
st++;
}
while(st <= dr && a[i] <= a[dq[dr]]){
dr--;
}
dq[++dr] = i;
if(i >= k){
sol += a[dq[st]];
}
}
g << sol;
return 0;
}