Cod sursa(job #2578715)

Utilizator BogdanFarcasBogdan Farcas BogdanFarcas Data 11 martie 2020 14:44:45
Problema Branza Scor 0
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.86 kb
#include <fstream>

using namespace std;

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

const int N=100001;
pair <int,int> dq[N];
int n,s,t,a,b,st=1,dr;
long long ans;

int main()
{
    fin>>n>>s>>t;
  //  ans=p[1].first*p[1].second;
  //  dq[++dr]=p[1].first;
    for(int i=1;i<=n;i++)
    {
        fin>>a>>b;
        if(i-dq[st].second>t&&st<=dr)
        {
            st++;
        }
        while(st<=dr&&dq[dr].first+s*(i-dq[dr].second)>=a)
        {
            dr--;
        }
        if(st>dr)
        {
            dq[++dr].first=a;
            dq[dr].second=i;
            ans+=b*dq[dr].first+s*(i-dq[dr].second);
        }
        else
        {
            ans+=b*dq[dr].first+s*(long long)(i-dq[dr].second)*b;
            dq[++dr].first=a;
            dq[dr].second=i;
        }
    }
    fout<<ans;
    return 0;
}