Pagini recente » Cod sursa (job #287512) | Cod sursa (job #2376246) | Cod sursa (job #888456) | Cod sursa (job #2250987) | Cod sursa (job #1059142)
#include <cstdio>
#include <deque>
using namespace std;
deque <int> a;
int b[5000005],n,k,i;
long long S;
int main ()
{
freopen ("deque.in","r",stdin);
freopen ("deque.out","w",stdout);
scanf("%d %d", &n,&k);
for (i=1; i<=n; i++)
{
scanf ("%d",&b[i]);
}
for (i=1; i<=n; i++)
{
if (!a.empty())
while (b[i]<b[a.back()])
{
a.pop_back();
}
a.push_back(i);
while (a.front()<=i-k)
{
a.pop_front();
}
if (i>=k)S+=b[a.front()];
}
printf ("%lld", S);
return 0;
}