Pagini recente » Cod sursa (job #2336560) | Cod sursa (job #1102602) | Cod sursa (job #220354) | Cod sursa (job #289822) | Cod sursa (job #1414282)
#include <cstdio>
#include <queue>
#define NMAX 5000005
using namespace std;
int A[NMAX], N, K;
long long sum;
deque <int> q;
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", &A[i]);
for (int i = 1; i <= N; ++i)
{
while (q.empty() == false && A[i] < A[q.back()])
q.pop_back();
q.push_back(i);
if (q.front() == i - K)
q.pop_front();
if (i >= K)
sum += A[q.front()];
}
printf("%lld", sum);
return 0;
}