Cod sursa(job #2616407)
| Utilizator | Data | 18 mai 2020 13:54:33 | |
|---|---|---|---|
| Problema | Branza | Scor | 0 |
| Compilator | cpp-64 | Status | done |
| Runda | Arhiva de probleme | Marime | 0.55 kb |
#include<bits/stdc++.h>
using namespace std;
ifstream f("branza.in");
ofstream g("branza.out");
int c[100001],p[100001],n,s,k,st=0,dr=-1,nanu[100001],rez=0;
int main(){
f>>n>>s>>k;
k++;
for(int i=0; i<n; i++)
f>>c[i]>>p[i];
for(int i=0; i<n; i++){
if(st<=dr && nanu[st]==(i-k)){
st++;
}
while(st<=dr && c[i]<=c[nanu[dr]]+(i-nanu[dr])*s){
dr--;
}
nanu[++dr]=i;
rez=rez+(c[nanu[st]]+(i-nanu[st])*s)*p[i];
}
g<<rez;
return 0;
}