Pagini recente » Cod sursa (job #1501913) | Cod sursa (job #1686501) | Cod sursa (job #14768) | Profil kuikrisz | Cod sursa (job #1861633)
#include <fstream>
using namespace std;
ifstream fin ("deque.in");
ofstream fout ("deque.out");
unsigned int N, K;
int arr[5000001];
int Deque[5000001];
unsigned int Front, Back;
unsigned int i;
long long int sum;
int main ()
{
fin >> N >> K;
for (i=1; i<=N; i++)
fin >> arr[i];
Front = 1;
for (i=1; i<=N; i++)
{
while (Front<=Back && arr[i]<=arr[Deque[Back]])
Back--;
Deque[++Back] = i;
if (Deque[Front] == i-K)
Front++;
if (i >= K)
sum += arr[Deque[Front]];
}
fout << sum << '\n';
return 0;
}