Pagini recente » Cod sursa (job #131093) | Cod sursa (job #1727154) | Cod sursa (job #494613) | Cod sursa (job #1471713) | Cod sursa (job #930286)
Cod sursa(job #930286)
#include <cstdio>
#define N 5000010
int a[N], Deque[N], n, k;
long long sum;
void prelucrare()
{
int 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\n", sum);
}
void citire()
{
scanf("%d %d ", &n, &k);
for (int i = 1; i <= n; i++)
scanf("%d ", &a[i]);
}
int main()
{
freopen("deque.in", "r", stdin);
freopen("deque.out", "w", stdout);
citire();
prelucrare();
return 0;
}