Pagini recente » Cod sursa (job #871941) | Cod sursa (job #2115397) | Cod sursa (job #2114887) | Istoria paginii runda/pregatire_oji2010i | Cod sursa (job #2767675)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
int n, k;
long long v[5005005];
int dq[5005005];
int st = 0, dr = -1;
int main()
{
fin >> n >> k;
for(int i = 1; i <= n; i ++)
{
fin >> v[i];
}
long long sum = 0;
for(int i = 1; i <= n; i ++)
{
if(i > k)
{
sum = sum + v[dq[st]];
if(dq[st] <= i - k)
st++;
}
while(st <= dr && v[dq[dr]] >= v[i])
{
dr--;
}
dq[++dr] = i;
}
sum = sum + v[dq[st]];
fout << sum << '\n';
return 0;
}