Cod sursa(job #1661197)

Utilizator MickeyTurcu Gabriel Mickey Data 23 martie 2016 18:00:23
Problema Deque Scor 25
Compilator cpp Status done
Runda Arhiva educationala Marime 0.59 kb
#include<stdlib.h>
#include<stdio.h>
#include<fstream>
#include<string.h>
#include<deque>
#include<algorithm>
using namespace std;
deque <long> D;
long n, k, i, s, v[5000010],front,back;

int main()
{
	ifstream f("deque.in");
	ofstream g("deque.out");
	f >> n >> k;
	for (i = 1;i <= n;i++)
	{
		f >> v[i];
	}

	for (i = 1;i <= n;i++)
	{
		while ((D.size() != 0) && (v[i] <= v[D.back()]))
			D.pop_back();
		D.push_back(i);
		
		if (i >= k)
		{
			s = s + v[D.front()];
			if (((D.size() != 0) && (i - D.front() >= k - 1)))
				D.pop_front();
		}
	}
	g << s;
	return 0;
}