Pagini recente » Monitorul de evaluare | Cod sursa (job #1571396) | Cod sursa (job #3341586) | Cod sursa (job #3322782) | Cod sursa (job #3322775)
#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;
for ( ll r = 0 ; r * l <= x ; ++ r )
{
ll j = 1 ;
priority_queue<ll>pq;
while ( j <= n && v[j].first + r * l <= x ){
if ( v[j].first + (r+1)*l > x )
pq.push(v[j].second);
++j;
}
if ( !pq.empty() )
{
suma += pq.top() ;
pq.pop();
}
}
fout << suma ;
return 0;
}