Pagini recente » Cod sursa (job #1477952) | Cod sursa (job #2775336) | Cod sursa (job #2648597) | Cod sursa (job #1178015) | Cod sursa (job #1971035)
#include <bits/stdc++.h>
#define MAXN 5000001
using namespace std;
int n, k, x, Queue[MAXN], Deque[MAXN];
int pr,ul=-1;
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 <= k; ++i)
{
scanf("%d", &x);
while(pr <= ul && Deque[ul] >= x) --ul;
++ul;
Deque[ul] = x;
Queue[ul] = i;
}
sum += Deque[pr];
for(int i = k + 1; i <= n; ++i)
{
scanf("%d", &x);
while(pr <= ul && Deque[ul] >= x) --ul;
++ul;
Deque[ul] = x;
Queue[ul] = i;
if(i - Queue[pr] + 1 > k) pr++;
sum += Deque[pr];
}
printf("%lld",sum);
return 0;
}