最少拦截系统

Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)

Problem Description

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

怎么办呢?多搞几套系统呗!你说说倒蛮容易,成本呢?成本是个大问题啊.所以俺就到这里来求救了,请帮助计算一下最少需要多少套拦截系统.

Input

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

Output

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

Sample Input

8 389 207 155 300 299 170 158 65

Sample Output

2

题解:这道题我是用贪心过的,首先保证每次拦截的损失最小(拦截系统下降的高度最小),如果无法拦截就再加一个拦截系统。其实每次让第一个能拦截的系统拦截就可以,这样整个数组自然就形成了一个上升序列。

后来看别人的题解,发现是最长上升序列问题,每一个数代表一个拦截系统的最小值,并且由于序列是上升的,每一个数都不能再拦截序列中的下一个数,因为下一个数更大,因此这个子序列的长度就是拦截系统数。

#include <iostream>
#include <cstdio> using namespace std; int main()
{
int dp[30050],n,i,j,num,x;
while(cin>>n)
{
num = 0;
for(i=0;i<n;i++)
{
scanf("%d",&x);
for(j=0;j<num;j++)
if(dp[j]>=x)
{
dp[j] = x;
break;
}
if(j==num)
dp[num++] = x;
}
printf("%d\n",num);
}
return 0;
}

最新文章

  1. Sharing A Powerful Tool For Calculate Code Lines
  2. java提高篇(十一)-----强制类型转换
  3. [转] git fetch与pull
  4. 2016.8.14 HTML5重要标签及其属性学习
  5. 如何使用VS2013对C++进行编程
  6. 关于表 datatable的条件查询
  7. void (*fun)(void);
  8. 04747_Java语言程序设计(一)_第3章_面向对象编程基础
  9. C# .net基于Http实现web server(web服务)
  10. Java大数应用
  11. 【python小练】0020
  12. mysql 去除重复 Select中DISTINCT关键字的用法 在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供 有distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记录的所有值。其原因是 distinct只能返回它的目标字段,而无法返回其它字段,这个问题让我困扰了很久,用distinct不能解决的话,
  13. Java中IO流中的装饰设计模式(BufferReader的原理)
  14. [2017BUAA软工]第0次作业
  15. 《转》12个Sublime Text使用技巧
  16. Oracle RAC管理及维护命令详解
  17. 表的复制——sql语句
  18. js如何获取到本周的第一天和最后一天,本月的第一天和最后一天以及本季度的第一天和最后一天
  19. 大数据技术Hadoop面试题
  20. bash: ./a.sh: /bin/bash^M: bad interpreter: No such file or directory的解决方法------dos---&gt;unix

热门文章

  1. Python 易错点
  2. textarea高度自动增高
  3. python 内置操作函数
  4. 洛谷P1077 [NOIP2012普及组]摆花 [2017年四月计划 动态规划14]
  5. Leetcode8.String to Integer (atoi)字符串转整数(atoi)
  6. Leetcode605.Can Place Flowers种花问题
  7. Centos系统Python环境搭建和项目部署
  8. Jquery选择器分类:基本选择器,层次选择器,过滤选择器,表单选择器。
  9. map.(parseInt)方法详解
  10. sublime3安装javascript控制台环境 方法1