題意:有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;
}