【HDU 1257】最少拦截系统(贪心)
来源:互联网 发布:五点共圆 知乎 编辑:程序博客网 时间:2024/06/16 02:06
最少拦截系统
Description
某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高度.某天,雷达捕捉到敌国的导弹来袭.由于该系统还在试用阶段,所以只有一套系统,因此有可能不能拦截所有的导弹.
怎么办呢?多搞几套系统呗!你说说倒蛮容易,成本呢?成本是个大问题啊.所以俺就到这里来求救了,请帮助计算一下最少需要多少套拦截系统.
Input
输入若干组数据.每组数据包括:导弹总个数(正整数),导弹依此飞来的高度(雷达给出的高度数据是不大于30000的正整数,用空格分隔)
Output
对应每组数据输出拦截所有导弹最少要配备多少套这种导弹拦截系统.
Sample Input
8 389 207 155 300 299 170 158 65
Sample Output
2
解题思路:
由于每个系统每次拦截的导弹只能是高度依次降低,要求最少的拦截系统个数,只能依次求出最长降序子序列并将此序列的所有元素划去(此时第二长的子序列就会变成最长),直至划至没有元素为止,并计数有多少个这样的子序列。
这是贪心的策略。此外,也可以用DP来解此题。
代码:
#include<iostream>#include<algorithm>#define MAX 10005using namespace std;int main(){ int n,k,height,temp[MAX]; while(cin>>n) { k=0; bool flag=false; cin>>height; temp[0]=height; k++; for(int i=1;i<n;i++) { flag=false; cin>>height; for(int j=0;j<k;j++) if(temp[j]>height) //此序列对于拦截系统已满足条件,最大值变小,flag=true表示满足条件,不需增加新的拦截系统 { temp[j]=height; flag=true; break; } if(!flag) temp[k++]=height;//若找到一个比前一个大的,计数器加1,即需要新的拦截系统 } cout<<k<<endl; } return 0; }
阅读全文
0 0
- hdu 1257 最少拦截系统(DP + 贪心)
- HDU 1257 最少拦截系统 贪心
- HDU 1257 最少拦截系统(贪心)
- hdu 1257 最少拦截系统(贪心,dp)
- hdu 1257 最少拦截系统 贪心
- hdu 1257 最少拦截系统 (贪心)
- HDU 1257 最少拦截系统 (贪心)
- hdu 1257最少拦截系统(贪心)
- HDU 1257最少拦截系统【贪心】
- hdu 1257 最少拦截系统(贪心)(简单)
- HDU 1257 最少拦截系统 (贪心)
- hdu 1257 最少拦截系统(贪心)
- hdu 1257 最少拦截系统 (贪心)
- HDU 1257 最少拦截系统 贪心
- HDU 1257最少拦截系统(贪心)
- HDU 1257 最少拦截系统【贪心】【DP】
- hdu 1257 最少拦截系统 贪心
- HDU 1257 最少拦截系统(贪心)
- 实现客户姓名添加和显示,修改
- C#读取txt文档并上传至数据库,将上传的数据逐行删除
- 硬盘分区表知识——详解硬盘MBR
- HDU
- Jenkins之定时构建
- 【HDU 1257】最少拦截系统(贪心)
- redis之主从复制
- 在服务器上创建虚拟机
- 登陆界面的数据存储(没有显式使用其他保存媒介)
- 千寻穗学习日记8.23
- rf报错集锦
- Caused by: org.apache.catalina.LifecycleException: A child container failed
- 为自己做的小计划 (电影类)-2
- 单调递增最长子序列