Cod sursa(job #2578720)
Utilizator | Data | 11 martie 2020 14:59:47 | |
---|---|---|---|
Problema | Branza | Scor | 0 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva de probleme | Marime | 0.65 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--;
}
dq[++dr].first=a;
dq[dr].second=i;
ans+=b*dq[st].first+s*(i-dq[st].second)*b;
}
fout<<ans;
return 0;
}