Pagini recente » Cod sursa (job #2423531) | Cod sursa (job #1860403) | Cod sursa (job #1173248) | Cod sursa (job #3033575) | Cod sursa (job #1059140)
#include <cstdio>
#include <deque>
using namespace std;
deque <int> a;
int b[5000001],n,k,i,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 ("%d", S);
return 0;
}