Pagini recente » Cod sursa (job #682143) | Cod sursa (job #1823391) | Cod sursa (job #474256) | Cod sursa (job #1866555) | Cod sursa (job #3126273)
#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 && a[i] <= a[dq[dr]]){
dr--;
}
dq[++dr] = i;
if(dq[st] == i - k + 1){
st++;
}
if(i >= k){
sol += a[dq[st]];
}
}
g << sol;
return 0;
}