Cod sursa(job #1259040)

Utilizator CostinVFMI CostinVictorGabriel CostinV Data 9 noiembrie 2014 17:36:23
Problema Lupul Urias si Rau Scor 28
Compilator cpp Status done
Runda Teme Pregatire ACM Unibuc 2014, Anul II Marime 0.78 kb
#include <fstream>
#include <vector>
#include <algorithm>
#include <queue>

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, i, tm=0;
	long long cl = 0;
	in>>n>>x>>l;
	vector<pair<int, int> > oi;
	priority_queue <int> que;

	for (i=0; i<n; i++)
	{
		in>>D>>L;
		if(D <= x)
		{
			oi.push_back(make_pair((x-D)/l, L));
			if ((x-D)/l > tm)
				tm = (x-D)/l;
		}

	}

	sort(oi.begin(), oi.end(), comp);

	int j=0;
	for(i=tm; i>=0; i--)
	{
		while(oi[j].first == i)
			que.push(oi[j++].second);

		if(!que.empty())
		{
			cl+=que.top();
			que.pop();
		}
	}

	out<<cl;

	
	return 0;
}