Pagini recente » Cod sursa (job #1734041) | Cod sursa (job #1514733) | Cod sursa (job #2854089) | Cod sursa (job #210525) | Cod sursa (job #2068759)
#include <bits/stdc++.h>
using namespace std;
deque <int> q;
const int nmax=1e6*5+5;
int n,k,x,v[nmax];
long long s;
int main() {
freopen("deque.in","r",stdin);
freopen("deque.out","w",stdout);
scanf("%d %d", &n, &k);
for (int i = 1; i <= n; ++i)
scanf("%d ", &v[i]);
for (int i = 1 ; i <= n; ++i) {
while (!q.empty() && v[i]<=v[q.back()])
q.pop_back();
q.push_back(i);
if (i - k > 0 && v[q.front()] == v[i - k]) q.pop_front();
if (i>=k) s+=1LL* v[q.front()];
}
printf("%lld", s);
return 0;
}