工作安排
题目描述

解题思路
我们先以时间为第一关键字、利润为第二关键字排序,然后贪心,在当前时间内选最大的利润。
code
#include<algorithm>
#include<iostream>
#include<cstdio>
#include<queue>
#define int long long
using namespace std;
priority_queue<int> q;
int n,m;
int ans;
struct abc{
int d,p;
}a[100010];
bool cmp(abc a,abc b)
{
if(a.d!=b.d)
return a.d<b.d;
return a.p>b.p;
}
signed main()
{
cin>>n;
for(int i=1;i<=n;i++)
scanf("%lld%lld",&a[i].d,&a[i].p),ans+=a[i].p;
sort(a+1,a+n+1,cmp);
for(int i=1;i<=n;i++)
{
q.push(-a[i].p);
m++;
if(m>a[i].d)
{
ans+=q.top();
q.pop();
m--;
}
}
cout<<ans<<endl;
}

本文介绍了一种使用贪心策略解决工作安排问题的方法,通过优先考虑时间和利润,对任务进行排序并动态调整,以求最大收益。代码展示了如何利用`priority_queue`实现这一过程。
245

被折叠的 条评论
为什么被折叠?



