Nu aveti permisiuni pentru a descarca fisierul grader_test20.ok

Cod sursa(job #593691)

Utilizator geniucosOncescu Costin geniucos Data 4 iunie 2011 11:40:16
Problema Deque Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.45 kb
#include<stdio.h>
using namespace std;
FILE *f,*g;
int k,n,i,p,u,a[5000002],d[5000002];
long long s;
int main()
{
f=fopen("deque.in","r");
g=fopen("deque.out","w");
fscanf(f,"%d",&n);
fscanf(f,"%d",&k);
for(i=1;i<=n;i++)
	fscanf(f,"%d",&a[i]);
p = 1;
for(i=1;i<=n;i++)
{
	while(p<=u && a[d[u]] >= a[i]) 
		u--;
	u++;
	d[u]=i;
	if(i-d[p]>=k) 
		p++;
	if(i>=k) 
		s = s+a[d[p]];
}
fprintf(g,"%lld",s);
fclose(f);
fclose(g);
return 0;
}