• 洛谷P2949题解


    若想要深入学习反悔贪心,传送门


    Description:

    (n) 项工作,每 (i) 项工作有一个截止时间 (D_i) ,完成每项工作可以得到利润 (P_i) ,求最大可以得到多少利润。

    Method:

    做这道题的时候并没有想到反悔贪心,只是想到一个错误的贪心算法。按照截止时间为第一关键字,利润为第二关键字排序,统计一遍即可。

    显然上面的贪心算法刻印被Hack掉。可以先不选择当前截止时间的利润,等一下选择下一个更大的利润,这样可以得到更大的最优解。

    但我们发现这个贪心策略错误的原因是当前的最优解可能不是全局最优解,显然符合反悔贪心的思想。于是我们用一个反悔堆维护最优解。

    假如满足题设条件(即没有超出截止时间)就分成两种情况:若当前的最优解比原来的最优解(堆顶)更优秀,我们就更新全局最优解,把原来的最优解丢出去,再把当前的最优解放进去(即反悔策略);反之,就不管了。假如不满足特设条件,就把当前的最优解丢进堆里,更新全局最优解即可。

    Code:

    #include<bits/stdc++.h>
    #define int long long 
    #define Maxn 100010
    inline void read(int &x)
    {
        int f=1;x=0;char s=getchar();
        while(s<'0'||s>'9'){if(s=='-')f=-1;s=getchar();}
        while(s>='0'&&s<='9'){x=x*10+s-'0';s=getchar();}
        x*=f;
    }
    using namespace std;
    int n;
    struct node
    {
        int D,P;
        bool operator <(const node &x)const
        {
            return D<x.D;
        }
    }job[Maxn];
    priority_queue<int,vector<int>,greater<int> >qu;
    signed main()
    {
        //	freopen("Job.in","r",stdin);
        //	freopen("Job.out","w",stdout);
        read(n);
        for(int i=1;i<=n;i++)
        {
            read(job[i].D),read(job[i].P);
        }
        sort(job+1,job+n+1);
        int ans=0;
        for(int i=1;i<=n;i++)
        {
            if(qu.size()>=job[i].D)//符合条件
            {
                if(qu.top()<job[i].P)//当前的最优解比原来的最优解(堆顶)更优秀
                {
                    ans-=qu.top();//更新全局最优解
                    qu.pop();//把原来的最优解丢出去
                    qu.push(job[i].P);//把当前的最优解放进去
                    ans+=job[i].P;//更新全局最优解
                }
            }else//不符合条件
            {
                qu.push(job[i].P);//把当前的最优解丢进堆里
                ans+=job[i].P;//更新全局最优解
            }
        }
        printf("%lld",ans);
        return 0;
    }
    
  • 相关阅读:
    使网页变灰的代码(包括FLASH等所有网页元素).
    技术面试问题回答
    Spring总结
    IE9插件差不多完成了
    通过dymamic简化Pinvoke调用
    shuffle算法的一种简易实现
    用Reactive Extensions快速实现鼠标手势功能
    编写递归调用的Lambda表达式
    Visual Studio 11 开发者预览版可以下载了
    关于获取所有排列方式的算法
  • 原文地址:https://www.cnblogs.com/nth-element/p/11785043.html
Copyright © 2020-2023  润新知