Cod sursa(job #1107857)

Utilizator federerUAIC-Padurariu-Cristian federer Data 14 februarie 2014 16:02:46
Problema Deque Scor 25
Compilator cpp Status done
Runda Arhiva educationala Marime 0.51 kb
#include<fstream>
#define Nmax 5000010
using namespace std;

ifstream fin("deque.in");
ofstream fout("deque.out");

int N, A[Nmax], deque[Nmax], front, back;
int i, K, sum;

int main()
{
	fin >> N>>K;
	for (i = 1; i <= N; ++i)
		fin >> A[i];

	front = 1, back = 0;
	for (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]];
	}
	fout << sum << '\n';
	return 0;
}