Cod sursa(job #462711)

Utilizator andrei.dAndrei Diaconeasa andrei.d Data 13 iunie 2010 00:16:00
Problema Branza Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.68 kb
#include <cstdio>

#define file_in "branza.in"
#define file_out "branza.out"

int n,s,t;
long long c[101000];
long long m[101000];
long long sol=0; 

void citire()
{
	freopen(file_in,"r",stdin);
	freopen(file_out,"w",stdout);
	
	scanf("%d %d %d", &n, &s, &t);
	for (int i=0;i<n;++i)
		 scanf("%lld %lld", &c[i], &m[i]);
}

void solve()
{
	int i,p,u;
	long long d[101000];
	
	p=1;
	u=0;
		
	for (i=0;i<n;++i)
	{
		while(p<=u && c[i]<=c[d[u]]+s*(i-d[u])) u--;
		d[++u]=i;
		if (d[p]<i-t) p++;
		sol+=(c[d[p]]+s*(i-d[p]))*m[i];
	}
	
	printf("%lld", sol);
}

int main()
{
	citire();
	solve();
	
	fclose(stdin);
	fclose(stdout);
	
	return 0;
	
}