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