Pagini recente » Cod sursa (job #1493320) | Cod sursa (job #2669055) | Cod sursa (job #1616274) | Cod sursa (job #2243854) | Cod sursa (job #2974678)
#include <fstream>
using namespace std;
ifstream fin ("branza.in");
ofstream fout("branza.out");
long long n,S,T,i,p,u,sol,D[100010],C[100010],P[100010];
int main ()
{
fin>>n>>S>>T;
for(i=1;i<=n;i++)
fin>>C[i]>>P[i];
D[1]=1;
p=1;
u=1;
sol=sol+C[1]*P[1];
for(i=2;i<=n;i++)
{
while(p<=u&&C[i]<=(i-D[u])*S+C[D[u]])
u--;
D[++u]=i;
if(i-D[p]==T+1)
p++;
sol=sol+(C[D[p]]+S*(i-D[p]))*P[i];
}
fout<<sol;
return 0;
}