Cod sursa(job #446929)

Utilizator marta_diannaFII Filimon Marta Diana marta_dianna Data 26 aprilie 2010 21:38:05
Problema Deque Scor 60
Compilator cpp Status done
Runda Arhiva educationala Marime 0.44 kb
#include<fstream.h>

long a[5000000], i, n, p, u, deque[5000000], k;
long long s;

int main()

{
	ifstream f("deque.in");
	ofstream g("deque.out");
	
	f>>n>>k;
	for (i=1;i<=n;i++) f>>a[i];
	
	deque[1]=1;u=1;p=1;s=0;
	for(i=2;i<=n;i++)
	{
		while (a[deque[u]]>=a[i] && u>p) u--;
		if (a[deque[u]]<a[i])u++;
		deque[u]=i;
		if (i-k==deque[p]) p++;
		if (i-k>-1) s+=a[deque[p]];
	}
	
	g<<s<<"\n";
	f.close();
	g.close();
}