题干:

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

Input

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

Output

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

Sample Input

8 389 207 155 300 299 170 158 65

Sample Output

2

解题报告:

这题的标解是最长上升子序列,但是严格证明过程较为复杂、、、(但是看上去是显然的?)

AC代码:(标解就是最长上升子序列的模板)

#include<bits/stdc++.h>using namespace std;
int dp[1000000 + 5],a[1000000 + 5];
int n;
int main()
{while(~scanf("%d",&n)) {for(int i = 1; i<=n; i++) scanf("%d",a+i),dp[i]=1;for(int 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);}}printf("%d\n",*max_element(dp+1,dp+n+1));}return 0 ;} 

AC代码2:(贪心可过、、但是我dp都没有初始化呀,,不知道是怎么AC的。、)

#include<bits/stdc++.h>using namespace std;
int n;
int a[1000 + 5];
int dp[1000 + 5];
int top;
int main()
{while(cin>>n) {top = 0;for(int i = 1; i<=n; i++) {scanf("%d",&a[i]);}for(int i = 1; i<=n; i++) {int minw = 0x3f3f3f3f;int mini = -1;for(int j = 1; j<=top; j++) {if(dp[j] >a[i] && dp[j] <= minw) {minw = dp[j];mini = j;}}if(mini == -1) {dp[++top] = a[i];}else dp[mini] = a[i];}printf("%d\n",top);}return 0 ;
}

【HDU - 1257】最少拦截系统 (标解dp,贪心可过,最长上升子序列类问题)相关推荐

  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 最少拦截系统 (DP)

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

  9. HDU 1257 最少拦截系统

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

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

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

最新文章

  1. InfoQ趋势报告:架构和设计领域技术演变详解
  2. 利用反射,泛型,静态方法快速获取表单值到Model。
  3. HDU1599 find the mincost route Floyd算法求最小环
  4. webpack(一) 配置
  5. mysql alert table 日志_MySQL日志
  6. java 线程 内存分配内存_漫谈JAVA语言的内存分配
  7. 微博广告推荐策略工程架构体系演进
  8. Java中构造函数,静态代码块,构造代码块的执行顺序
  9. EJB(RMI学习)
  10. Palindrome - URAL - 1297(求回文串)
  11. java实验报告遇到的问题,JAVA实验报告_doc
  12. 2019华为软件精英挑战赛总结
  13. android电视与苹果手机图片,小米电视怎么投屏?图文讲解安卓和苹果手机投屏到小米电视方法...
  14. 准备计算机二级c语言需要多久,计算机二级自学需要准备多久
  15. 差分 离散化 (线段树优化lazy标记)2018ICPC SouthEastern Fishermen
  16. 从零开始自制实现WebServer(十九)---- 正式系统的学习一下Git 捣鼓捣鼓github以及一些其他的小组件
  17. 无capwap隧道的分布式网关实现思路
  18. 解决单点故障 - 有状态服务的高可用
  19. 【科研绘图】PS绘制封面中神奇的放大效果
  20. 【css3文字阴影+盒子阴影+过渡+2d转换+3d转换】

热门文章

  1. 【Breadth-first Search 】279. Perfect Squares
  2. [密码学基础][每个信息安全博士生应该知道的52件事][Bristol Cryptography][第17篇]述和比较DES和AES的轮结构
  3. jdk安装失败_windows配置安装单个Tomcat
  4. rs232串口驱动_电脑主板RS232串口硬件设计
  5. memset和fill
  6. 在struts2中push方法的使用_【干货】网版印刷中水墨使用注意事项及助剂使用方法...
  7. python编程口诀_少儿Python编程中的算术与技巧
  8. java漂亮界面编程_计算机二级之JAVA篇
  9. eventfd以及epoll原理分析
  10. Socket的send函数在执行时报EAGAIN的错误