版权声明:本文为博主原创文章,未经博主允许不得转载。 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;
}