Cod sursa(job #420051)

Utilizator Cristy94Buleandra Cristian Cristy94 Data 18 martie 2010 13:20:24
Problema Branza Scor 40
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.72 kb
#include<stdio.h>
FILE *f=fopen("branza.in","r");
FILE *g=fopen("branza.out","w");
long long i,j,m[100001],n,t,s,rez;
int c[100001],w[1000001];
long long deque[100001],u,p;

int main(){
//***citire***//	
fscanf(f,"%lld%lld%lld",&n,&s,&t);
for(i=1;i<=n;i++)
	fscanf(f,"%lld%lld",&c[i],&w[i]);

//***dinamica***//
p=1;
for(i=1;i<=n;i++)  // m[i]=costul minim pt a cumpara un kg de branza in ziua i
{ j=i-t;
  deque[i]=c[i];
  while(p<i&&(i-p>t|| deque[p]+(i-p)*s > deque[i] ) )
	  p++;
  m[i]=deque[p]+(i-p)*s;
 /* if(j<1)
	   j=1;
  for(;j<i;j++)
	  if( m[i] > c[j]+s*(i-j) ) // depoziteaza branza in ziua j
		     m[i]=c[j]+s*(i-j);
*/
}
for(i=1;i<=n;i++)
	rez+=m[i]*w[i];
fprintf(g,"%lld",rez);
return 0;
}