Pagini recente » Cod sursa (job #2281486) | Cod sursa (job #1552111) | Cod sursa (job #1412269) | Cod sursa (job #2061596) | Cod sursa (job #3331486)
#include <fstream>
#include <deque>
int c[100000],p[100000];
using namespace std;
ifstream fin("branza.in");
ofstream fout("branza.out");
int main(){
int 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;
}