Pagini recente » Cod sursa (job #1792117) | Cod sursa (job #1365554) | Cod sursa (job #446844) | Cod sursa (job #1300914) | Cod sursa (job #1258848)
#include <fstream>
#include <vector>
#include <algorithm>
using namespace std;
bool comp (pair<int, int> x, pair<int, int> y)
{
if(x.first < y.first || x.first > y.first)
return x.first<y.first;
return x.second>y.second;
}
int main()
{
ifstream in ("lupu.in");
ofstream out ("lupu.out");
int n, x, l, D, L, cl=0, al=0, i, dm=0;
in>>n>>x>>l;
vector<pair<int, int> > oi;
for (i=0; i<n; i++)
{
in>>D>>L;
if(D <= x)
{
oi.push_back(make_pair((x-D)/l, L));
if (D > dm)
dm = D;
}
}
sort(oi.begin(), oi.end(), comp);
for(i=0; i<n; i++)
{
if(oi[i].first>=al)
{
cl+=oi[i].second;
al++;
}
if(al > dm/l)
break;
}
out<<cl;
return 0;
}