Cod sursa(job #401860)

Utilizator Cristi09Cristi Cristi09 Data 23 februarie 2010 09:59:32
Problema Deque Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.51 kb
#include<stdio.h>
int n,k,d[2][5001000];
int main()
{
	FILE*f=fopen("deque.in","r");
	fscanf(f,"%d%d",&n,&k);
	int i,front,back,val,ok;
	long long s=0;
	for(i=front=back=0;i<n;++i)
	{
		fscanf(f,"%d",&val);
		while(front<=back&&val<=d[1][back]&&i)
			{--back;}
		if(i)++back;
		d[0][back]=i;
		d[1][back]=val;
		
		if(i-k>=d[0][front])
			++front;
		
		if(i>=k-1)
		{
			s+=d[1][front];
		}
	}
	fclose(f);
	FILE*g=fopen("deque.out","w");
	fprintf(g,"%lld\n",s);
	fclose(g);
	return 0;
}