Pagini recente » Cod sursa (job #2767177) | Cod sursa (job #1212806) | Cod sursa (job #1848277) | Cod sursa (job #317146) | Cod sursa (job #2450063)
#include <cstdio>
#include <deque>
using namespace std;
int n, k;
deque <pair <int, int>> dq;
long long ans = 0;
int main() {
freopen ("deque.in", "r", stdin);
freopen ("deque.out", "w", stdout);
scanf("%d %d", &n, &k);
for (int i = 1; i <= n; i++) {
int x;
scanf("%d", &x);
while (!dq.empty() && x <= dq.back().first) {
dq.pop_back();
}
dq.push_back({x, i});
if (i - dq.front().second + 1 > k) {
dq.pop_front();
}
if (i >= k) {
ans += dq.front().first;
}
}
printf("%lld\n", ans);
return 0;
}