hdu 1257 最少拦截系统(动态规划 / 贪心)
最少拦截系统
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 11667 Accepted Submission(s): 4585
怎么办呢?多搞几套系统呗!你说说倒蛮容易,成本呢?成本是个大问题啊.所以俺就到这里来求救了,请帮助计算一下最少需要多少套拦截系统.
这道题实际上是重复求“最长非递增子序列”的过程。具体过程是重复倒序求最长非降(注意,实际上是非降)子序列,然后将每一次求出的最长非降序列剔除(将序列的每个值赋0),直到全部剔除(原序列全部变为0),剔除的次数就是至少要设置的拦截系统的数量。
“倒序求最长非降子序列”即是求“最长非升子序列”(可以理解为“最长递减子序列”),可以想象,要求最长递减子序列,只要倒着求最长递增子序列就行了。为什么要这样求?因为动态规划里没有方法直接求最长递减子序列,只能通过最长递增子序列间接求最长递减子序列。
之前不太明白什么是“最长递增子序列”,从网上找了段解释看明白了:
“所谓动态规划法就是从最后一个元素开始找递减子序列并记下该元素的位置和子序列的长度
例如 对于题目中的 序列 9 8 2 1 7 5 3 4 3 2 1
最后一个元素 是 1 ,它的位置是 11 ,最长递减子序列的长度是 1
倒数第二个元素 是 2 ,它的位置是 10,最长递减子序列的长度是 2 (递减子序列为:2 1)
倒数第三个元素是 3,位置是9,最长递减子序列长度是3 (递减子序列为 3 2 1)
倒数第四个元素是4 ,位置是8 ,最长递减子序列长度是4 (递减子序列为4 3 2 1)
倒数五个元素是3 ,位置7,最长递减子序列长度是3 (递减子序列为 3 2 1,这里注意不是 4 3 2 1,因为4 比倒数第五个元素3 大所以实际上是 后面的 2 1 这个子序列加上倒数第五个元素3 组成的 3 2 1)
...
一直求解出每个元素的最长递减子序列的长度
然后找出所有元素中最长的子序列长度.例如本例上最长的子序列长度就是第一个元素长度为8
最后就是根据该 长度 还原出该 子序列。
还原方法就是 递减循环 子序列的长度 找出对应的元素 位置.再根据位置获取到对应的值
例如 子序列长度为8 对应的为第一个元素 即 9
递减后为 7 对应的为第二个元素 即 8
以此类推 最后还原出得到序列9 8 7 5 4 3 2 1 ”
#include <iostream>
using namespace std; int main()
{
int n,a[];
while(cin>>n){
int i,index;
for(i=;i<=n;i++) //输入数组
cin>>a[i];
//找到最长非升子序列 int count=; while(true){
for(i=;i<=n;i++) //检测
if(a[i]!=) break; //全部为0,即将全部序列剔除之后退出循环
if(i>n) break; for(i=n;i>=;i--){
if(a[i]!=){
index=i; //标记倒序第一个不是0的数
break;
}
}
for(i=n-;i>=;i--){
if(a[i]==) continue;
if(i==index) continue;
if(a[i]>=a[index]) {a[index]=;index=i;} //比较当前数和标记的数。如果大于等于标记的上一个数,则将上次标记的数等于0,将本次标记。
}
a[index]=; //将最后标记的不是0的数赋值0
// for(i=1;i<=n;i++)
// cout<<a[i]<<' ';
// cout<<endl;
count++;
}
cout<<count<<endl; }
return ;
}
2014/1/20 16:21:27
重新做了一遍,赫然发现贪心也可以AC。
下面给出代码,仅供参考:
#include <iostream>
using namespace std;
int main()
{
int n,a[];
while(cin>>n){
for(int i=;i<=n;i++)
cin>>a[i];
int b[]; //记录每个拦截系统的当前拦截高度
int count=;
for(int i=;i<=n;i++){
if(count==) //还没开始计数
b[++count] = a[i];
else{ //开始计数
int j;
for(j=;j<=count;j++) //将记录的所有系统的拦截高度和当前导弹高度依次比较
if(a[i]<=b[j]){ //遇到小于某个拦截高度,代替那个高度
b[j] = a[i];
break;
}
if(j>count){ //当前高度比记录的最小高度都要大,再建立一套拦截系统
count++;
b[count] = a[i];
}
}
}
cout<<count<<endl;
}
return ;
}
Freecode : www.cnblogs.com/yym2013
hdu 1257 最少拦截系统(动态规划 / 贪心)的更多相关文章
- HDU 1257 最少拦截系统(贪心 or LIS)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1257 最少拦截系统 Time Limit: 2000/1000 MS (Java/Others) ...
- HDU 1257最少拦截系统[动态规划]
传送门:http://acm.hdu.edu.cn/showproblem.php?pid=1257 最 ...
- hdu 1257 最少拦截系统【贪心 || DP——LIS】
链接: http://acm.hdu.edu.cn/showproblem.php?pid=1257 http://acm.hust.edu.cn/vjudge/contest/view.action ...
- HDU 1257 最少拦截系统 (DP || 贪心)
最少拦截系统 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Submit Statu ...
- POJ - 2533 Longest Ordered Subsequence与HDU - 1257 最少拦截系统 DP+贪心(最长上升子序列及最少序列个数)(LIS)
Longest Ordered Subsequence A numeric sequence of ai is ordered if a1 < a2 < ... < aN. Let ...
- HDU——1257最少拦截系统(贪心)
最少拦截系统 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Sub ...
- 题解报告:hdu 1257 最少拦截系统(贪心)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1257 Problem Description 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是 ...
- POJ 1065 Wooden Sticks / hdu 1257 最少拦截系统 DP 贪心
参考链接:http://blog.csdn.net/xiaohuan1991/article/details/6956629 (HDU 1257 解题思路一样就不继续讲解) POJ 1065题意:给你 ...
- HDU 1257 最少拦截系统 【贪心】
<题目链接> 题目大意: 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高度 ...
- hdu 1257 最少拦截系统(简单贪心)
题目:http://acm.hdu.edu.cn/showproblem.php?pid=1257 虽然分类是dp感觉还是贪心 比较水 #include <iostream> #inclu ...
随机推荐
- PotPlayer 进度条显示缩略图
PotPlayer设置鼠标放在播放器进度条任意位置显示缩略图 迁移时间--2017年8月9日15:41:27Author:Marydon 右键-->选项(F5)-->点击左侧面板上的“ ...
- springmvc验证数据
1.引入jar包 com.springsource.javax.validation-1.0.0.GA.jar 规范(只是定义) hibernate-validator-4.1.0.Final.ja ...
- 如何使用Android MediaStore裁剪大图片
译者按:在外企工作的半年多中花了不少时间在国外的网站上搜寻资料,其中有一些相当有含金量的文章,我会陆陆续续翻译成中文,与大家共享之.初次翻译,“信达雅”三境界恐怕只到信的层次,望大家见谅! 这篇文章相 ...
- No persister for nhibernate 解决下面的问题
在你的实体类对应的配置文件点右键选择属性,修改类型为:一直复制和嵌入的资源.就可以了.
- IOS性能调优系列:使用Allocation动态分析内存使用情况
硬广:<IOS性能调优系列>第三篇,持续更新,欢迎关注. <IOS性能调优系列:Analyze静态分析>介绍了使用静态分析方法查找IOS内存泄漏的方法,<IOS性能调优系 ...
- Hive 中的变量
Hive的变量前面有一个命名空间,包括三个hiveconf,system,env,还有一个hivevar hiveconf的命名空间指的是hive-site.xml下面的配置变量值. system的命 ...
- 关闭windows打印服务
1.关闭打印服务:开始-运行-services.msc或打开控制面板-管理工具-服务,打开服务列表,找到Print Spooler(打印服务),关闭(右击,点“关闭”).2.删除打印缓存:进入c:\\ ...
- 56. Two Sum【easy】
Given an array of integers, find two numbers such that they add up to a specific target number. The ...
- nyoj983 首尾相连数组的最大子数组和
首尾相连数组的最大子数组和 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 给定一个由N个整数元素组成的数组arr,数组中有正数也有负数,这个数组不是一般的数组,其首尾是 ...
- service文件(格林速洗项目)
service文件模板:String url="http://59.78.93.208:9097/Order?id="+id+"&value="+val ...