有N个任务,每个任务有一个最晚结束时间以及一个对应的奖励。在结束时间之前完成该任务,就可以获得对应的奖励。完成每一个任务所需的时间都是1个单位时间。有时候完成所有任务是不可能的,因为时间上可能会有冲突,这需要你来取舍。求能够获得的最高奖励。
Input
第1行:一个数N,表示任务的数量(2 <= N <= 50000)
第2 - N + 1行,每行2个数,中间用空格分隔,表示任务的最晚结束时间Eii以及对应的奖励Wii。(1 <= Eii <= 10^9,1 <= Wii <= 10^9)
Output
输出能够获得的最高奖励。
Sample Input
7 4 20 2 60 4 70 3 40 1 30 4 50 6 10
Sample Output
230
#include<iostream>
#include<algorithm>
#include<queue>
#include<vector>
using namespace std;
struct k
{
int e,w;
}a[50005];
int cmp(k x,k y) //把最晚结束时间从小到大排,若其相等,则按奖励从大到小排;
{
if(x.e==y.e)
return x.w>y.w;
else
return x.e<y.e;
}
int main()
{
int n,i,j;
priority_queue<int ,vector<int>,greater<int> >q;
while(~scanf("%d",&n))
{
long long sum=0;
for(i=0;i<n;i++)
cin>>a[i].e>>a[i].w;
while(!q.empty()) //这样做更加保险,清空优先队列
{
q.pop();
}
sort(a,a+n,cmp);
for(i=0;i<n;i++)
{
if(a[i].e>q.size()) //q的大小代表着已经用过的时间,如果第i个任务的最晚结束时间大于q.size,则将其入队。
{
q.push(a[i].w);
}
else
if(a[i].e==q.size()&&a[i].w>q.top()) //如果某一任务最晚结束时间等于已经用过的时间,且他的奖励比已入队的所有奖励都大时,将队首弹出,将其入队
{
q.pop();
q.push(a[i].w);
}
}
while(!q.empty()) // 累加,算奖励
{
sum+=q.top();
q.pop();
}
cout<<sum<<endl;
}
return 0;
}