Pagini recente » Cod sursa (job #1875270) | Cod sursa (job #3187759) | Cod sursa (job #2131315) | Cod sursa (job #2806363) | Cod sursa (job #2545103)
#include <bits/stdc++.h>
using namespace std;
ifstream f("branza.in");
ofstream g("branza.out");
deque <int> q;
int n,S,t,i,min_val,cant,suma,cost[100100];
int main()
{
f>>n>>S>>t;
for(i=1;i<=n;i++)
{
f>>cost[i]>>cant;
while(!q.empty() && cost[i]<=(cost[q.back()]+S*(i-q.back())))q.pop_back();
q.push_back(i);
while(i-q.front()>t)q.pop_front();
min_val=cost[q.front()]+S*(i-q.front());
suma+=min_val*cant;
}
g<<suma;
return 0;
}