Pagini recente » Cod sursa (job #471805) | Cod sursa (job #391681) | Cod sursa (job #74227) | Cod sursa (job #813816) | Cod sursa (job #984204)
Cod sursa(job #984204)
# include <iostream>
# include <fstream>
# include <deque>
using namespace std;
ifstream f("dequeue.in");
ofstream g("dequeue.out");
# define MAXN 500010
int n, k, sum = 0;
int a[MAXN];
deque<int> coada;
int main()
{
f >> n >> k;
for (int i = 1; i <= n; i++) {
f >> a[i];
}
for (int i = 1; i <= n; i++) {
while(!coada.empty() && a[i] <= a[coada.back()]) {
coada.pop_back();
}
coada.push_back(i);
if (coada.front() == i - k) {
coada.pop_front();
}
if (i >= k)
sum += a[coada.front()];
}
g << sum;
return 0;
}