Pagini recente » Cod sursa (job #629175) | Cod sursa (job #2328524) | Cod sursa (job #1315928) | Monitorul de evaluare | Cod sursa (job #3309864)
#include <bits/stdc++.h>
using namespace std;
typedef long long i8;
int main() {
ifstream cin("deque.in");
ofstream cout("deque.out");
int n, k;
cin >> n >> k;
vector<long long> v(n + 2, 0);
for (int i = 1; i <= n; i++) {
cin >> v[i];
}
deque<int> d;
long long res = 0;
for (int i = 1; i <= n; i++) {
while (!d.empty() && v[i] <= v[d.back()]) {
d.pop_back();
}
d.push_back(i);
if (i >= k) {
if (d.front() <= i - k) {
d.pop_front();
}
res += v[d.front()];
}
}
cout << res << "\n";
}