Cod sursa(job #2761518)

Utilizator GligarEsterabadeyan Hadi Gligar Data 2 iulie 2021 15:36:59
Problema Branza Scor 0
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.67 kb
#include <fstream>
#include <queue>

using namespace std;

ifstream fin("branza.in");
ofstream fout("branza.out");

const int nmax=100000;

int c[nmax+1], p[nmax+1];

deque <int> dq;

typedef long long int64;

int main(){
    int n,s,t;
    fin>>n>>s>>t;
    for(int i=1;i<=n;i++){
        fin>>c[i]>>p[i];
    }
    int64 sol=0;
    for(int i=1;i<=n;i++){
        while(dq.empty()==0&&c[dq.back()]+(i-dq.back())*s>c[i]){
            dq.pop_back();
        }
        dq.push_back(i);
        if(dq.front()<=i-t){
            dq.pop_front();
        }
        sol+=int64((c[dq.front()]+(i-dq.front())*s)*p[i]);
    }
    fout<<sol<<"\n";
    return 0;
}