习题:专业网络(贪心)

Posted loney-s

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了习题:专业网络(贪心)相关的知识,希望对你有一定的参考价值。

题目

传送门

思路

首先有一点必须明确
我们买这个人不是因为要满足他的要求,而是因为他便宜
对于(a_i==n)的情况
这些人明摆了就不想和你做朋友
所以你必须拿钱来买
考虑对解决(a_i)的需求
解决(a_i)的需求的时候,
所有的(a_j<a_i)的j已经解决了
剩下的只能从(a_i<a_k)中获取
之后,就这么解决了

代码

#include<iostream>
#include<vector>
#include<queue>
using namespace std;
int n;
int tot;
int ans;
vector<int> v[200005];
priority_queue<int,vector<int>,greater<int> > q;
int main()
{
    cin>>n;
    for(int i=1;i<=n;i++)
    {
        int a,b;
        cin>>a>>b;
        v[a].push_back(b);
    }
    for(int i=0;i<v[n].size();i++)
    {
        ans=ans+v[n][i];
    }
    tot=n;
    for(int i=n-1;i>=1;i--)
    {
        tot=tot-v[i].size();
        for(int j=0;j<v[i].size();j++)
            q.push(v[i][j]);
        while(tot<i)
        {
            ans+=q.top();
            q.pop();
            tot++;
        }
    }
    cout<<ans;
    return 0;
}

以上是关于习题:专业网络(贪心)的主要内容,如果未能解决你的问题,请参考以下文章

习题—动态规划贪心算法

第十四周周总结

2021算法竞赛入门班第一节课枚举贪心习题

习题:疫情控制(二分+倍增+贪心)

习题:changing array (贪心)

贪心LuoguP5653 基础最优化练习题 (我想不到的贪心