Pagini recente » Cod sursa (job #2978107) | Cod sursa (job #3312025) | Cod sursa (job #1645623) | Cod sursa (job #1923335) | Cod sursa (job #3331590)
#include <fstream>
#include <deque>
using namespace std;
long long c[100000],p[100000];
deque <int> dq;
ifstream fin("branza.in");
ofstream fout("branza.out");
int main(){
long long n,i,t,s;
long long sum=0;
fin >>n >> s >> t;
for(i=0;i<n;i++){
fin >> c[i] >> p[i];
while (!dq.empty()&&c[i]<=c[dq.back()]+s*(i-dq.back()))
dq.pop_back();
dq.push_back(i);
if(dq.front()==i-t)
dq.pop_front();
sum+=p[i]*(c[dq.front()]+s*(i-dq.front()));
}
fout << sum;
return 0;
}