Pagini recente » Cod sursa (job #2278551) | Cod sursa (job #2807418) | Cod sursa (job #1134462) | Cod sursa (job #77315) | Cod sursa (job #2388715)
#include <fstream>
#include <deque>
#define N 100100
using namespace std;
ifstream cin("branza.in");
ofstream cout("branza.out");
int n,s,t,b[N],c[N];
unsigned long long sum;
struct chestie{
int ind,m;
}ch;
deque <chestie> mom;
int main()
{
cin>>n>>s>>t;
for(int i=1;i<=n;i++)
{
cin>>b[i]>>c[i];
while(!mom.empty() && (mom.back().ind+t<i ||mom.back().m+s*(i-mom.back().ind)>=b[i]))
mom.pop_back();
while(!mom.empty() && mom.front().ind+t<i)
mom.pop_front();
mom.push_back({i,b[i]});
ch=mom.front();
sum=sum+(ch.m+s*(i-ch.ind))*c[i];
}
cout<<sum<<'\n';
return 0;
}