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

Input

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

Output

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

Sample Input

8 389 207 155 300 299 170 158 65

Sample Output

2

思路:
也就是求依次递减的子序列个数
状态转移方程为:dp[i] = max(dp[i], dp[j]+1) (a[i]>a[j]&&1≤j≤i) 此方法时间复杂度为O(n^2)
初始状态都默认认为所有导弹都用1号系统拦截 假如第i个导弹大于前面的导弹 则dp[i]至少比第j个导弹大1
dp[i]为拦截当前导弹所用的系统号
例如:9 389 207 155 300 299 170 158 65 70
389 207 155 70 用系统1
300 299 170 158 65用系统2

#include <stdio.h>
#define N 30001int a[N], dp[N];
int max(int a, int b) {return a>b ? a : b;
}int main()
{int n, i;a[0] = N;while (scanf("%d", &n) != EOF){for (i = 1; i <= n; i++) {dp[i] = 1;scanf("%d", &a[i]);}for (i = 1; i <= n; i++){for (int  j = 1; j <=i; j++){if (a[i]>a[j])dp[i]=max(dp[i],dp[j]+1);}}int ans = 0;for (i = 1; i <= n; i++)ans = max(ans, dp[i]);printf("%d\n", ans);}return 0;
}

转载于:https://www.cnblogs.com/Chizhao/p/10439781.html

HDU 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 最少拦截系统

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

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

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

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

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

最新文章

  1. 渗透知识-SQL注入
  2. windows update失败还原更改,无法开机
  3. MFC- OnIdle空闲处理
  4. 半导体八大工艺流程图_半导体之光刻胶,看五大龙头谁能迈出国产化第一步?...
  5. Python中的staticmethod和classmethod
  6. 《CSS权威指南(第3版)》要点摘记
  7. python读取lmdb文件_LMDB文件读取器
  8. java矩阵连乘动态规划_动态规划之矩阵连乘
  9. Ubuntu WPS字体缺失
  10. ad板子挖孔_用AD软件画孔的注意了!
  11. 直播带货这么火,如何在小程序中实现视频通话及直播互动功能?
  12. 20189200余超 2018-2019-2 移动平台应用开发实践第九周作业
  13. js 鼠标拖拽改变div宽度高度
  14. 安全信息管理系统(OSSIM)
  15. C++:实现量化默认概率曲线测试实例
  16. 透过达达财报看同城零售赛道价值,平台规模化增长后撑起更大价值
  17. 计算机网络(四)网络层详解
  18. java网络爬虫0基础_简单的java爬虫程序(入门)
  19. 安卓系统采用v4l2接口打开YUYV和MJPEG摄像头,支持热插拔。
  20. CRM系统免费版和商业版区别

热门文章

  1. 计算机组成原理作业3,兰州大学《计算机组成原理》13春在线作业3
  2. python应用题_Python简单应用题
  3. python opencv 录制视频_python - 使用Opencv Python多线程录制视频 - 堆栈内存溢出
  4. List集合中对象的排序
  5. mysql_数据备份和迁移(Windows)
  6. php rabbitmq延迟队列示例
  7. CF 468B Two Sets
  8. 【BZOJ】1579: [Usaco2009 Feb]Revamping Trails 道路升级
  9. Linux之cut命令
  10. Shell命令_for