D. Yet Another Monster Killing Problem 貪心

傳送

題意:有n個怪獸 ,每個怪獸都有能力值a[i]。

然後現在你有m個英雄,每個英雄也有能力值p[i],每個英雄還有一個s[i],表示這個英雄一天最多能消滅多少個怪獸

現在你必須一個接一個的消滅怪獸,不能改變順序,然後問你最少多少天,能夠消滅所有的怪獸。

思路:維護一個 耐久度 數組

#include<bits/stdc++.h>
using namespace std;
const int maxn=2e5+10;
int a[maxn];
int per[maxn];
int p[maxn],s[maxn];
int main()
{
    int t;
    scanf("%d",&t);
    while(t--)
    {
        int n;
        scanf("%d",&n);
        int maxm=0,maxp=0;
        for(int i=1;i<=n;i++)
        {
            scanf("%d",&a[i]);
            maxm=max(maxm,a[i]);
            per[i]=0;
        }
        int m;
        scanf("%d",&m);
        for(int i=1;i<=m;i++)
        {
            scanf("%d%d",&p[i],&s[i]);
            maxp=max(maxp,p[i]);
            per[s[i]]=max(per[s[i]],p[i]); // 一樣耐久度的最大值
        }
        if(maxp<maxm)
        {
            printf("-1\n");
            continue;
        }
        for(int i=n-1;i>=1;i--)
        {
            per[i]=max(per[i],per[i+1]);//如果後一個耐久度高 且傷害高 肯定選這個了最優
        }
        int ans=0;
        int cur=0;
        int cnt=0;
        for(int i=1;i<=n;i++)
        {
             cur=max(cur,a[i]);
             cnt++;
             if(per[cnt]<cur)
             {
                 ans++;// 將前面的怪物消滅
                 cnt=1;
                 cur=a[i];// 必然是a[i]這個怪物沒有存下
             }
        }
        ans++;// 必然有一個沒有統計
        printf("%d\n",ans);
    }
    return 0;
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章