Cod sursa(job #3357994)
| Utilizator | Data | 13 iunie 2026 22:44:04 | |
|---|---|---|---|
| Problema | Deque | Scor | 0 |
| Compilator | cpp-64 | Status | done |
| Runda | Arhiva educationala | Marime | 0.65 kb |
#include <iostream>
#include <fstream>
#include <deque>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
int main() {
int n, k;
fin >> n >> k;
deque<int> dq;
int64_t ans = 0;
for (int i = 0; i < n; ++i) {
int x;
fin >> x;
while (!dq.empty() && dq.back() >= x) {
dq.pop_back();
}
dq.push_back(x);
if (!dq.empty() && dq.front() <= x) {
while (!dq.empty() && dq.front() <= i - k + 1) {
dq.pop_front();
}
}
if (i >= k - 1) {
ans += dq.front();
}
}
fout << ans;
return 0;
}