打地鼠游戏(贪心+优先队列使用)

打地鼠游戏(贪心+优先队列使用)_第1张图片

万遍红中带点绿,不过学会了一些有技巧吧。

就是会用那个优先队列了。

https://blog.csdn.net/stand1210/article/details/52464922

这个题就是贪心。

弄一个结构体,在把时间排序一下。

分两部分:

  1. 第一种可能:未雨绸缪  ( t < p [ i ] . t )
  2. 第二种可能:抉择( t > = p [ i ] . t )

讨论两种情况即可:

但是里面用到了优先队列进行维护:

priority_queue< int, vector ,  greater < int > >que; 升序 top:Min

priority_queue< int >que ;降序 top:Max

贴上代码:

#include
using namespace std;
typedef long long ll;
typedef struct node{
    ll T,x;
    node(ll t=0,ll X=0):T(t),x(X){}
    friend bool operator < (const node & p1, const node & p2){
        return p1.T , greater >que;
    ll n;
    scanf("%lld",&n);
    ll sumT=-1,sum=0;
    for(int i=0;i=p[i].T){
            ll tmp=que.top();
            if(tmp

以下是杨哥哥发给我的: 

#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define INF 0x3f3f3f3f
#define gcd(a,b) __gcd(a,b)
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define FAST_IO ios::sync_with_stdio(false)
#define mem(a,b) memset(a,b,sizeof(a))
const double PI = acos(-1.0);
const double eps = 1e-6;
const int MAX=1e5+10;
const int mod=1e9+7;
typedef long long ll;
using namespace std;
 
int vis[1000005];
struct node
{
    int t,v;
}p[1000005];
 
int cmp(node a,node b)
{
    return a.v>b.v;
}
 
int main()
{
    int n;
    scanf("%d",&n);
 
    for(int i=1;i<=n;i++)
        scanf("%d",&p[i].t);
    for(int i=1;i<=n;i++)
        scanf("%d",&p[i].v);
 
    sort(p+1,p+1+n,cmp);
 
    int ans=0;
    for(int i=1;i<=n;i++)
    {
        int t=p[i].t;
        while(vis[t]) t--;
 
        if(t)
        {
            vis[t]=1;
            ans+=p[i].v;
        }
    }
 
    cout<

 

你可能感兴趣的:(优先队列,贪心,中石油)