Cod sursa(job #68052)
| Utilizator | Data | 26 iunie 2007 12:39:25 | |
|---|---|---|---|
| Problema | Branza | Scor | 0 |
| Compilator | cpp | Status | done |
| Runda | Arhiva de probleme | Marime | 0.42 kb |
#include<stdio.h>
long long x;
int n,t,s,p[100001],c[100001],i,j;
int main()
{freopen("branza.in","r",stdin);
freopen("branza.out","w",stdout);
scanf("%d %d %d",&n,&s,&t);
for(i=1;i<=n;i++)
scanf("%d %d",&p[i],&c[i]);
for(i=1;i<n;i++)
for(j=1;j<=t&&i+j<=n;j++)
if(p[i]+s*j<p[i+j])
p[i+j]=p[i]+s*j;
for(i=1;i<=n;i++)
x+=(long long)p[i]*c[i];
printf("%lld",x);
fclose(stdout);
return 0;}
