Pagini recente » Cod sursa (job #340190) | Cod sursa (job #879475) | Cod sursa (job #29299) | Cod sursa (job #1611851) | Cod sursa (job #2892270)
#include <iostream>
#include <fstream>
#include <deque>
using namespace std;
deque <int> mydeq;
int n,s,t,rsp;
long long v[100002],p[100002];
int main()
{
ifstream f ("branza.in");
ofstream g ("branza.out");
f>>n>>s>>t;
for (int i=1; i<=n; i++)
{
f>>v[i]>>p[i];
while (!mydeq.empty() && i-mydeq.front()>t) mydeq.pop_front();
while (!mydeq.empty() && (i-mydeq.back())*s+v[mydeq.back()]>=v[i]) mydeq.pop_back();
mydeq.push_back(i);
rsp=rsp+v[mydeq.front()]*p[i]+p[i]*(i-mydeq.front())*s;
}
g<<rsp;
}