Pagini recente » Cod sursa (job #289479) | Cod sursa (job #592014) | Cod sursa (job #2547484) | Rating Gociu Maria Anastasia (Maryy_1369) | Cod sursa (job #462706)
Cod sursa(job #462706)
#include <cstdio>
#define file_in "branza.in"
#define file_out "branza.out"
int n,s,t;
int c[101000];
int m[101000];
void citire()
{
freopen(file_in,"r",stdin);
freopen(file_out,"w",stdout);
scanf("%d %d %d", &n, &s, &t);
for (int i=1;i<=n;++i)
scanf("%d %d", &c[i], &m[i]);
}
void solve()
{
int i,p,u;
int d[101000];
p=1;
u=0;
long long sol=0;
for (i=1;i<=n;++i)
{
while(p<=u && c[i]<=c[d[u]]+s*(i-d[u])) u--;
d[++u]=i;
sol+=(long long)(c[d[p]]+s*(i-d[p]))*m[i];
if (d[p]<i-t) p++;
}
printf("%lld", sol);
}
int main()
{
citire();
solve();
fclosE(stdin);
fclose(sdtout);
return 0;
}