这题是这样的
题目描述
某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统。但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能高于前一发的高度。某天,雷达捕捉到敌国的导弹来袭。由于该系统还在试用阶段,所以只有一套系统,因此有可能不能拦截所有的导弹。
输入导弹依次飞来的高度,计算这套系统最多能拦截多少导弹,如果要拦截所有导弹最少要配备多少套这种导弹拦截系统。
输入格式
一行,若干个整数,中间由空格隔开。
输出格式
两行,每行一个整数,第一个数字表示这套系统最多能拦截多少导弹,第二个数字表示如果要拦截所有导弹最少要配备多少套这种导弹拦截系统。
输入输出样例
输入 #1
389 207 155 300 299 170 158 65
输出 #1
6 2
说明/提示
对于前 50% 数据(NOIP 原题数据),满足导弹的个数不超过 10^4 个。该部分数据总分共 100 分。可使用O(n^2) 做法通过。
对于后 50% 的数据,满足导弹的个数不超过 10^5 个。该部分数据总分也为 100 分。请使用 O(nlogn) 做法通过。
对于全部数据,满足导弹的高度为正整数,且不超过 5×10^4。
此外本题开启 spj,每点两问,按问给分。
NOIP1999 提高组 第一题
upd 2022.8.24:新增加一组 Hack 数据。
这题有很多写法
用二分优化
用dp动态规划来写
用贪心也可以
我推荐大家用dp写
比较简单
以下是代码
#include <bits/stdc++.h>
using namespace std;
int n,a[100010],f[100010],p[100010];
int ans1,ans2;
int main(){
while(scanf("%d",&a[++n])!=EOF);
n--;
for(int i=1;i<=n;i++){
f[i]=1;
for(int j=1;j<=i-1;j++)
if(a[i]<=a[j])
f[i]=max(f[i],f[j]+1);
ans1=max(ans1,f[i]);
}
for(int i=1;i<=n;i++){
p[i]=1;
for(int j=1;j<=i-1;j++)
if(a[i]>a[j])
p[i]=max(p[i],p[j]+1);
ans2=max(ans2,p[i]);
}
printf("%d\n%d",ans1,ans2);
return 0;
}
点个赞吧!!!求求了!!!
632

被折叠的 条评论
为什么被折叠?



