Pagini recente » Cod sursa (job #2073811) | Clasament preoli10 | Cod sursa (job #993177) | Cod sursa (job #2301865) | Cod sursa (job #2578711)
#include <fstream>
using namespace std;
ifstream fin("branza.in");
ofstream fout("branza.out");
const int N=100001;
pair <int,int> dq[N];
int n,s,t,a,b,st=1,dr;
long long ans;
int main()
{
fin>>n>>s>>t;
// ans=p[1].first*p[1].second;
// dq[++dr]=p[1].first;
for(int i=1;i<=n;i++)
{
fin>>a>>b;
if(i-dq[st].second>t)
{
st++;
}
while(st<=dr&&dq[dr].first+s*(i-dq[dr].second)>=a)
{
dr--;
}
if(st>dr)
{
dq[++dr].first=a;
dq[dr].second=i;
ans+=b*dq[dr].first+s*(i-dq[dr].second);
}
else
{
ans+=b*dq[dr].first+s*(i-dq[dr].second)*b;
dq[++dr].first=a;
dq[dr].second=i;
}
}
fout<<ans;
return 0;
}