1618: 【动态规划】拦截导弹

题目描述

张琪曼:“老师,修罗场是什么?”

墨老师:“修罗是佛家用语,修罗毕生以战斗为目标,修罗场指的是他们之间的死斗坑,人们通常用‘修罗场’来形容惨烈的战场。后来又引申出‘一个人在困境中做绝死奋斗’的意思。所以,这其实也在暗示我们,即使是身处绝境,也不要放弃奋斗。再说了,情况其实没有这么糟糕,因为我们最新的导弹拦截系统已经研制好了。”

魔法世界为了防御修罗王军团的导弹袭击,开发出一种导弹拦截系统──“要你命3000”。但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能高于前一发的高度。某天,雷达捕捉到修罗王军团的导弹来袭。由于该系统还在试用阶段,所以只有一套系统,因此有可能不能拦截所有的导弹。

输入导弹依次飞来的高度(雷达给出的高度数据是不大于30000 的正整数),计算这套系统最多能拦截多少导弹和如果要拦截所有导弹最少要配备多少套这种导弹拦截系统。

 

输入

一行,为导弹依次飞来的高度

 

输出

这套系统最多能拦截多少导弹,如果要拦截所有导弹最少要配备多少套这种导弹拦截系统。

 

样例输入

复制样例数据

389 207 155 300 299 170 158 65

样例输出

6
2

 

来源/分类

NOIP1999提高组 

 

[提交] [状态]

 

 

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
const int maxn=1001;
int dp1[maxn],a[maxn],dp2[maxn];
int main()
{
    int n=1;
    while(scanf("%d",&a[n])!=EOF)
    {
        dp1[n]=1;
        dp2[n]=1;
        n++;
    }
    //输出一次最多拦截的导弹个数
    for(int i=1;i<n;i++)
        for(int j=1;j<i;j++)
    {
        if(a[i]<=a[j]) dp1[i]=max(dp1[i],dp1[j]+1);
    }
    
    cout<<*max_element(dp1+1,dp1+n)<<endl;
    //求最长上升子序列的长度
    for(int i=1;i<n;i++)
        for(int j=1;j<i;j++)
    {
        if(a[i]>a[j]) dp2[i]=max(dp2[i],dp2[j]+1);
    }
    cout<<*max_element(dp2+1,dp2+1+n);
    return 0;




}

附上一个参考的链接:有关求不升(下降)子序列个数

规律:下降子序列的个数等于最长上升子序列的长度。

在一个序列里,不上升子序列的个数等于最长上升子序列的长度

反过来也一样 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值