Pagini recente » Monitorul de evaluare | Monitorul de evaluare | Cod sursa (job #1068794) | Cod sursa (job #3315242) | Cod sursa (job #3309247)
#include <fstream>
#include <deque>
#include <tuple>
using namespace std;
ifstream fin("branza.in");
ofstream fout("branza.out");
deque<pair<int,int>>deq;
int n,x,k,s,ans,t;
int main()
{
fin >>n >>s >>t;
for(int i = 1;i <= n;i++)
{
fin >>x >>k;
while(!deq.empty())
{
if(x <= deq.back().first + s*(i-deq.back().second))
{
deq.pop_back();
}
else
{
break;
}
}
deq.push_back({x,i});
if(i - deq.front().second > t)
{
deq.pop_front();
}
ans += k * (deq.front().first + s * (i - deq.front().second));
}
fout <<ans;
return 0;
}