Pagini recente » Cod sursa (job #1140137) | Cod sursa (job #1675343) | Cod sursa (job #2207241) | Cod sursa (job #2702184) | Cod sursa (job #2940094)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("branza.in");
ofstream fout("branza.out");
long long n, s, t, c[1000002], kg[1000002], i, r;
deque<long long> q;
int main() {
fin >> n >> s >> t;
for(i = 1; i <= n; i++) fin >> c[i] >> kg[i];
for(i = 1; i <= n; i++) {
while(!q.empty() && c[i] <= c[q.back()] + s * (i - q.back())) q.pop_back();
q.push_back(i);
if(i > t + q.front()) q.pop_front();
r += kg[i] * s * (i - q.front()) + kg[i] * c[q.front()];
}
fout << r;
return 0;
}