最少拦截系统
Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 39448    Accepted Submission(s): 15465

Problem Description
某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高度.某天,雷达捕捉到敌国的导弹来袭.由于该系统还在试用阶段,所以只有一套系统,因此有可能不能拦截所有的导弹.
怎么办呢?多搞几套系统呗!你说说倒蛮容易,成本呢?成本是个大问题啊.所以俺就到这里来求救了,请帮助计算一下最少需要多少套拦截系统.

Input
输入若干组数据.每组数据包括:导弹总个数(正整数),导弹依此飞来的高度(雷达给出的高度数据是不大于30000的正整数,用空格分隔)

Output
对应每组数据输出拦截所有导弹最少要配备多少套这种导弹拦截系统.

Sample Input
8 389 207 155 300 299 170 158 65

Sample Output
2

Source
浙江工业大学第四届大学生程序设计竞赛 
 
题意就是  给出一行数据表示导弹的弹射高度  已知系统是只能拦截比上一次射的导弹低一点的导弹 求该数串所用的最少拦截系统是多少

这道题其实就是求最长递增子序列 为什么这么说呢

假设我们从第一个数开始向后遍历,有所拦截的都是递减序列 一旦我们遇到一个导弹高度 比上一个导弹高度高的 就说明该增加拦截系统了

然后再来一个递减序列 又遇到了一个数比上一个数大时 此时需要考虑 如果这个数 比前面更新导弹系统更大时 说明前一个导弹系统hold不住了

需要再加一个导弹系统 如果这时的数小于更换导弹系统前的数 那么不必要更新 所以这道题目所有更新导弹系统的时候 还是在递增序列的时候

所以求的是最长递增子序列长度

求的方法就是 尽可能构造最大元素尽可能小的递增序列

n*logn复杂度

#include<bits/stdc++.h>
using namespace std;
int a[1010];
int main()
{int n;while(cin>>n){for(int i=1;i<=n;++i)cin>>a[i];int res=0;int ans[1010]={0};for(int i=1;i<=n;i++)   {if(a[i]>ans[res])ans[++res]=a[i];else {int* pos = lower_bound(ans+1,ans+1+res,a[i]);*pos=a[i];}}cout<<res<<endl; }return 0;
} 

当然还可以用dp做  n*n复杂度

#include<bits/stdc++.h>
using namespace std;
int a[1010],d[1010];
int main()
{ios::sync_with_stdio(0);int n;while(cin>>n){for(int i=1;i<=n;i++)cin>>a[i];for(int i=1;i<=n;i++){d[i]=1;for(int j=1;j<i;j++)if(a[i]>a[j]&&d[j]+1>d[i])d[i]=d[j]+1;}int m=0;for(int i=1;i<=n;i++)m = max(m,d[i]);cout<<m<<endl; }return 0;
} 

HDOJ-1257 最少拦截系统相关推荐

  1. hdu 1257最少拦截系统(贪心)

    最少拦截系统 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Sub ...

  2. hdu 1257最少拦截系统 动态规划

    最少拦截系统 Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other) Problem Desc ...

  3. HDU 1257 最少拦截系统【最长上升子序列】

    解题思路:可以转化为求最长上升子序列来做,还是可以用an与按升序排列后的an求LCS来做,为防止超时,用滚动数组优化一下就可以了. 最少拦截系统 Time Limit: 2000/1000 MS (J ...

  4. HDU——1257最少拦截系统(贪心)

    最少拦截系统 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Sub ...

  5. 题解报告:hdu 1257 最少拦截系统(贪心)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1257 Problem Description 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是 ...

  6. HDU 1257 - 最少拦截系统 ( LIS / 贪心 )

    题目 现在有一种拦截系统,第一发拦截可以是任意高度,但是之后的拦截高度不能比上次高.为了拦截下所有的炮弹,最少需要准备几套拦截系统? 思路 可能是语文没学好吧,一开始被题意卡了一下.(而且题目连数据范 ...

  7. HDU 1257 - 最少拦截系统

    某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高度.某天,雷达捕捉到敌国的导弹来袭.由于 ...

  8. HDU 1257 最少拦截系统

    /* 若N个数 为递增序列 则最多需要N个导弹系统 贪心 + DP 见注释 */ #include <stdio.h> #define MAX 100000 int height[MAX] ...

  9. HDU 1257 最少拦截系统(贪心)

    解题思路:用一个vector存下数据,从头开始非递增遍历,并把符合条件的删除,一次操作,ans++,当vector为空时退出循环.(PS:学到了vector的erase操作,竟然还有返回值,涨姿势了) ...

  10. hdu 1257 最少拦截系统 (DP)

    点击打开链接 #include"stdio.h" int main() {int a[10011],b[10011];int i,j,c,n;while(scanf("% ...

最新文章

  1. 134个预训练模型、精度高达85.1%,百度视觉算法最强基石PaddleClas全新升级
  2. 【 Vivado 】输入延迟约束实例
  3. win7如何取消计算机管理员权限,win7如何删除需要管理员权限的文件夹
  4. phpcms v9 数据库操作函数
  5. 新闻系统粗略说明文档
  6. 最简单的爬虫代码 python_最精简的爬虫 --仅需4行代码(python)
  7. 【转】关于python中re模块split方法的使用
  8. 前端复习笔记(一)——HTML
  9. 小议新版GB9706.1-2020的基本性能
  10. T0.Games欢迎高端加密NFT入驻
  11. 美国华盛顿州通过 ArcBlock 支持的区块链法案
  12. Android基础篇-四大组件之使用ContentProvider实现数据共享
  13. 3D 小游戏《飞跃地平线 Plus》开发分享
  14. 每页都有的表头和打印分页
  15. 怎样彻底删除 mac 上的 Adobe 相关文件?
  16. 工作中一个管理者的态度
  17. 集 8 万员工之力, Google 开放 Bard,我们将它和 ChatGPT 正面 PK 了一下
  18. 组FreeNas11.3的一点心得
  19. 64位操作系统安装——Linux(Ubuntu 16.04)+Windows7+iNode
  20. Python+uiautomator2手机UI自动化测试实战 -- 2. 用法介绍

热门文章

  1. android studio -genymotion神奇错误
  2. Lab1--关于安装JUnit的简要描述
  3. hdu4011(水贪心)
  4. win10使用docker desktop安装k8s一直starting解决方法
  5. cad中线段求和lisp_cad中连续线段变更圆滑弧形
  6. java面试技术问题_11个JAVA面试中常见技术问题
  7. linux 常用 启动命令 汇总
  8. filter过滤器实现验证跳转_返回验证结果
  9. mock 生成在线图片
  10. html5语异性元素,异性的5句性暗示