Cod sursa(job #431440)

Utilizator za_wolfpalianos cristian za_wolf Data 31 martie 2010 23:47:04
Problema Deque Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.52 kb
//#include "stdafx.h"
#include<stdio.h>
#define NMAX 5000010
#define inf 10000100
int q[NMAX],x[NMAX],s,a,i,n,k,in,sf,m,min;
long long rez;
int main()
{
	freopen("deque.in","r",stdin);
	freopen("deque.out","w",stdout);
	scanf("%d%d",&n,&k);
	in=1;
	sf=0;
	min=inf;
	for (i=1;i<=n;i++)
	{
		scanf("%d",&a);
		while (sf>=in&&a<q[sf])
			sf--;
		q[++sf]=a;
		x[sf]=i;
		
		if (i>=k)
		{
			rez+=q[in];
			printf("%d ",q[in]);
		}

		if (i-x[in]+1==k)
			in++;
	}
	printf("%d\n",rez);



	return 0;
}