Cod sursa(job #321800)

Utilizator taloibogdanTaloi Bogdan Cristian taloibogdan Data 7 iunie 2009 13:46:08
Problema Branza Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.5 kb
#include<stdio.h>
struct branza{long long s;long i;}a[100500];
long n,s,t,st,dr,i;
long long cc,ca,ss,S;
int main()
{
 freopen("branza.in","r",stdin);
 freopen("branza.out","w",stdout);
 scanf("%ld%ld%ld",&n,&s,&t);
 st=1;
 dr=0;
 for(i=1;i<=n;++i)
    {scanf("%ld%ld",&cc,&ca);
     ss=cc+(n-i)*s;
     while(dr&&a[dr].s>ss)--dr;
     a[++dr].s=ss;
     a[dr].i=i;
     while(a[st].i<=i-t&&st<=dr)++st;
     ss=a[st].s;
     ss-=((n-i)*s);
     S+=(ss*ca);}
 printf("%ld\n",S);
 return 0;
}