Pagini recente » Cod sursa (job #1656357) | Cod sursa (job #996827) | Cod sursa (job #3309847) | Cod sursa (job #3332777) | Cod sursa (job #3331487)
#include <fstream>
#include <deque>
long long c[100000],p[100000];
using namespace std;
ifstream fin("branza.in");
ofstream fout("branza.out");
int main(){
long long n,i,t,s;
long long sum=0;
deque <int> dq;
fin >>n >> s >> t;
for(i=0;i<n;i++){
fin >> c[i]>>p[i];
}
for(i=0;i<n;i++){
while(!dq.empty()&&c[i]<=c[dq.back()]+s*(i-dq.back())){
dq.pop_back();
}
dq.push_back(i);
if(dq.front() == i-t){
dq.pop_front();
}
printf("%d " ,dq.front());
sum+=(c[dq.front()]+s*(i-dq.front()))*p[i];
}
fout << sum;
return 0;
}