Pagini recente » Cod sursa (job #995474) | Cod sursa (job #695253) | Cod sursa (job #2780127) | Cod sursa (job #1579367) | Cod sursa (job #2620051)
#include <bits/stdc++.h>
using namespace std;
ifstream f("branza.in");
ofstream g("branza.out");
int n, s, t, k;
int v[100005];
long long sum;
deque <int> d;
int main()
{
f >> n >> s >> t;
for(int i = 1; i <= n; i++)
{
f >> v[i] >> k;
if(!d.empty() && d.front() == i - t) ///daca s a depasit nr de t zile
d.pop_front();
while(!d.empty() && 1LL * (v[d.back()] + (i-d.back()) * s >)= v[i] ) ///daca costul minim + taxa de depoazitare >= costul curent
d.pop_back();
d.push_back(i);
sum += 1LL * k * (v[d.front()] + 1LL * (i-d.front()) * s);
}
g << sum;
return 0;
}