思路
这道题我一开始想到一个憨批做法在YbtOJ上过了正当我沾沾自喜的时候——
实际上正解是:
考虑贪心,如果当前工作可选,那么就把它加入要做行列中,否则就在要做的堆中选择一个利润最小的(堆头)踢出。
代码
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<queue>
using namespace std;
long long n,ans,c;
priority_queue<long long> q;
struct node
{
int d,p;
}a[100010];
bool cmp(const node&x,const node&y)
{
return x.d<y.d;
}
int main()
{
cin>>n;
for(int i=1; i<=n; i++)
scanf("%lld%lld",&a[i].d,&a[i].p);
sort(a+1,a+1+n,cmp);
for(int i=1; i<=n; i++)
{
q.push(-a[i].p);
c++;
if(c>a[i].d)
{
q.pop();
c--;
}
}
while(!q.empty())
ans-=q.top(),q.pop();
cout<<ans;
return 0;
}