51Nod 1163 最高的奖励(贪心)

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_42391248/article/details/85224723

按照奖励从大到小排序

比如测试案例:

70 60 50 40 30 20 10

 4  2   4   3   1    4   6

用一个数组ans[i]记录要完成的任务:

      先将70放到4的位置,然后将60放到2的位置,然后将50放到4的位置,但是4的位置已经有70了,就往前找空位即放到3的位置。就是这个思想,比较像哈希函数解决冲突的开放地址法。

#include<iostream>
#include<algorithm>
#include<cstring>
#include<string>
#include<vector>
using namespace std;
typedef long long ll;
struct node{
	int t1,t2;
}a[50005];
bool cmp(node a,node b)
{
	if(a.t2==b.t2)
		return a.t1<b.t1;
	return a.t2>b.t2;
}
int main()
{
	int n,i;
	cin>>n;
	for(i=0;i<n;i++)
		cin>>a[i].t1>>a[i].t2;
	ll ans[50005];
	memset(ans,0,sizeof(ans));
	sort(a,a+n,cmp);
	for(i=0;i<n;i++)
	{
		int t=a[i].t1;
		while(ans[t]!=0)
			t--;
		if(t==0) continue;
//		cout<<t<<" "<<a[i].t2<<endl;
		ans[t]=a[i].t2;
	}
	ll sum=0;
//	for(i=1;i<=n;i++)
//		cout<<ans[i]<<endl;
	for(i=1;i<=n;i++)
		sum+=ans[i];
	cout<<sum<<endl;
	return 0;
}

猜你喜欢

转载自blog.csdn.net/qq_42391248/article/details/85224723