Pagini recente » Borderou de evaluare (job #1228821) | Cod sursa (job #528016) | Cod sursa (job #3318641) | Monitorul de evaluare | Cod sursa (job #3322778)
#include <bits/stdc++.h>
#define ll long long
using namespace std;
ifstream fin ( "lupu.in" ) ;
ofstream fout ( "lupu.out" ) ;
pair<ll,ll> v[100005];
signed main()
{
ll n , x , l ;
fin >> n >> x >> l ;
for ( ll i = 1 ; i <= n ; ++ i )
fin >> v[i].first >> v[i].second;
sort(v+1,v+n+1);
ll suma = 0;
ll j = n ;
for ( ll r = 0 ; r * l <= x ; ++ r )
{
priority_queue<int>pq;
while ( j >= 1 && v[j].first + (r+1) * l > x ){
if ( v[j].first + r*l <= x )
pq.push(v[j].second);
--j;
}
if ( !pq.empty() )
{
suma += pq.top() ;
pq.pop();
}
}
fout << suma ;
return 0;
}