Cod sursa(job #270526)

Utilizator M@2Te4iMatei Misarca M@2Te4i Data 4 martie 2009 09:23:06
Problema Deque Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.45 kb
#include<cstdio>
struct ddd
{
	int val,poz;
}deq[5000000];

int n,k,i,st,dr,x;

int main()
{
	freopen("deque.in","r",stdin);
	freopen("deque.out","w",stdout);
	long long sol=0;
	scanf("%d%d",&n,&k);
	st=dr=0;
	for(i=1;i<=n;++i){
		scanf("%d",&x);
		if(deq[st].poz<=i-k)
			++st;
		while(deq[dr].val>x && dr>=st)
			--dr;
		deq[++dr].val=x;
		deq[dr].poz=i;
		if(i>=k)
			sol+=deq[st].val;
	}
	printf("%lld\n",sol);
	return 0;
}