Pagini recente » Cod sursa (job #939417) | Cod sursa (job #1868383) | Cod sursa (job #1813353) | Cod sursa (job #500468) | Cod sursa (job #2630310)
#include <iostream>
#include <fstream>
#include <deque>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
deque <int> q;
int n, k, el, v[5000005];
long long sum;
int main() {
fin >> n >> k;
for (int i = 1; i <= n; ++i)
fin >> v[i];
for (int j = 1, i = 1; j <= n; ++j) {
if (j > k) {
++i;
if (!q.empty()) {
sum += v[q.front()];
while (q.front() < i) {
q.pop_front();
if (q.empty())
break;
}
}
}
if (!q.empty())
while (v[j] < v[q.back()]) {
q.pop_back();
if (q.empty())
break;
}
q.push_back(j);
}
if (!q.empty())
sum += v[q.back()];
fout << sum;
return 0;
}