Pagini recente » Cod sursa (job #1938279) | Autentificare | Cod sursa (job #2521092) | Cod sursa (job #2378544) | Cod sursa (job #1815813)
#include <cstdio>
#define minim(a,b) ((a < b) ? a : b)
#define maxn 5000010
using namespace std;
int n,k;
int a[maxn],deque[maxn];
int front,back;
long long sum;
int main()
{
int a1;
freopen("deque.in","r",stdin);
freopen("deque.out","w",stdout);
scanf("%i %i",&n,&k);
for(int i=1;i<=n;i++)
scanf("%i",&a[i]);
front = 1,back = 0;
for(int i=1;i<=n;i++)
{
while(front <= back && a[i] <= a[deque[back]])
back--;
deque[++back] = i;
if(deque[front] == i-k)
front++;
if(i >= k)
sum+= a[deque[front]];
}
printf("%lld",sum);
return 0;
}