Pagini recente » Cod sursa (job #2329028) | Cod sursa (job #36157) | Cod sursa (job #2124304) | Cod sursa (job #2156114) | Cod sursa (job #2053096)
#include <fstream>
using namespace std;
ifstream cin("branza.in");
ofstream cout("branza.out");
const int nm=100005;
int n,s,t,sol[nm],d[nm],st=1,dr=0,sum=0;
struct fint
{
int c,p;
};
fint v[nm];
int main()
{
cin>>n>>s>>t;
for(int i=1;i<=n;i++)
cin>>v[i].c>>v[i].p;
for(int i=1;i<=n;i++)
{
while(st<=dr and v[i].c<=v[d[dr]].c+10*(i-d[dr]))
dr--;
if(st<=dr and d[st]==i-t+1)
st++;
d[++dr]=i;
sol[i]=d[st];
}
for(int i=1;i<=n;i++)
sum+=v[i].p*(v[sol[i]].c+10*(i-sol[i]));
cout<<sum;
return 0;
}