Pagini recente » Cod sursa (job #3274824) | Cod sursa (job #2578962) | Cod sursa (job #3004875) | Cod sursa (job #476113) | Cod sursa (job #3270685)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
int n, a[5000005], k;
long long suma;
deque<int> q;
int main()
{
int i, x;
fin >> n >> k;
for(i = 1; i <= n; i++)
fin >> a[i];
for(i = 1; i <= k; i++)
{
x = a[i];
while(!q.empty() && x <= a[q.back()])
q.pop_back();
q.push_back(i);
}
suma = a[q.front()];
for(i = k + 1; i <= n; i++)
{
x = a[i];
while(!q.empty() && x <= a[q.back()])
q.pop_back();
q.push_back(i);
if(q.front() == i - k) q.pop_front();
suma += a[q.front()];
}
fout << suma << "\n";
return 0;
}