Pagini recente » Cod sursa (job #2919089) | Cod sursa (job #1052450) | Cod sursa (job #2999873) | Cod sursa (job #2654593) | Cod sursa (job #2176287)
#include <cstdio>
#define NMAX 5000002
using namespace std;
int n, k, V[NMAX], Deque[NMAX];
int Front, Back;
long long Sum;
int main()
{
freopen("deque.in", "r", stdin);
freopen("deque.out", "w", stdout);
scanf("%d%d", &n, &k);
for(int i=1; i<=n; i++)
scanf("%d", &V[i]);
Front=1;Back=0;
for(int i=1; i<=n; i++)
{
while(Front<=Back&&V[i]<=V[Deque[Back]]) Back--;
Deque[++Back]=i;
if(Deque[Front]==i-k) Front++;
if(i>=k)
Sum=Sum+V[Deque[Front]];
}
printf("%lld\n", Sum);
return 0;
}