最少拦截系统

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 31611    Accepted Submission(s): 12412

Problem Description
某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高度.某天,雷达捕捉到敌国的导弹来袭.由于该系统还在试用阶段,所以只有一套系统,因此有可能不能拦截所有的导弹.
怎么办呢?多搞几套系统呗!你说说倒蛮容易,成本呢?成本是个大问题啊.所以俺就到这里来求救了,请帮助计算一下最少需要多少套拦截系统.
Input
输入若干组数据.每组数据包括:导弹总个数(正整数),导弹依此飞来的高度(雷达给出的高度数据是不大于30000的正整数,用空格分隔)
Output
对应每组数据输出拦截所有导弹最少要配备多少套这种导弹拦截系统.
Sample Input
8 389 207 155 300 299 170 158 65
Sample Output
2

做法:每次按拦截完将当前高度更新,一直往后扫,直到拦截完所有导弹(这题很多题解有BUG,一些数据是错误的,也许我这份代码也有错误)

代码:

#include<iostream>
#include<algorithm>
#include<cstdlib>
#include<sstream>
#include<cstring>
#include<cstdio>
#include<string>
#include<deque>
#include<cmath>
#include<queue>
#include<set>
#include<map>
using namespace std;
int pos[100010];
int main (void)
{ios::sync_with_stdio(false);int t,n,i,j,ans;while (cin>>n){memset(pos,0,sizeof(pos));for (i=0; i<n; i++){cin>>pos[i];}int temp=pos[0];int cnt=0,ans=0;for (i=0; i<n; i++){if(pos[i]!=-1){temp=pos[i];for (j=i; j<n; j++){if(pos[j]!=-1&&pos[j]<=temp){temp=pos[j];//更新拦截高度pos[j]=-1;//标记已拦截过cnt++;//拦截数更新                      }}ans++;//拦截一轮加一套防御系统}if(cnt==n)//全部拦截完毕,break{break;}   }cout<<ans<<endl;}return 0;
}

转载于:https://www.cnblogs.com/Blackops/p/5380417.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 最少拦截系统(贪心)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1257 Problem Description 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是 ...

  5. HDU 1257 - 最少拦截系统 ( LIS / 贪心 )

    题目 现在有一种拦截系统,第一发拦截可以是任意高度,但是之后的拦截高度不能比上次高.为了拦截下所有的炮弹,最少需要准备几套拦截系统? 思路 可能是语文没学好吧,一开始被题意卡了一下.(而且题目连数据范 ...

  6. HDU 1257 - 最少拦截系统

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

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

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

  8. HDU 1257 最少拦截系统

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

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

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

最新文章

  1. gitlab+jenkins+maven+docker持续集成(四)——Extended E-mail Notification配置
  2. 我是如何自学 Python 的
  3. python库开源网站_开源Python库
  4. CRITICAL_SECTION的详细说明
  5. 使用Tkinter的Label组件写一个广告板招租
  6. python安装卡在core inter_python – 如何在我的机器上安装numpy / core ...
  7. leetcode990. 等式方程的可满足性(并查集)
  8. 利用可分离卷积UNet进行木薯叶病分类
  9. java获取发件人_如何获取发件人outlook / Exchange的SMTP地址
  10. LPC1768的USB-相关结构体定义
  11. MyEclipse暗黑主题设置
  12. SPOJ-SUBST1 New Distinct Substrings (求不同子串数量)(后缀数组模板)
  13. 两无线路由器连接方法
  14. 学习Python全套代码【超详细】Python入门、核心语法、数据结构、Python进阶【致那个想学好Python的你】
  15. 求最大公约数及求多个数的最大公约数
  16. 在EXCEL使用VLOOKUP函数实现自动匹配
  17. 计算机如果添加新用户名,怎么在电脑中创建新用户
  18. 特征工程(科大讯飞阿泽大佬share)
  19. 2013传智播客视频--.ppt,.pptx,.doc,.docx.目录
  20. android 死亡自动启动,android – 服务在Activity的’死亡’崩溃

热门文章

  1. Proxy error: Could not proxy request错误解决
  2. input隐藏域赋值数组
  3. PowerDesigner生成SQL
  4. springMVC中获取request 对象
  5. oracle总是未响应,求教 pl/sql连接本机数据库是未响应问题
  6. dhcp服务器批量修改ip租期,dhcp服务器的ip地址租期默认是多久
  7. Graph Theory
  8. solving order
  9. 千寻位置 开发demo_CICV2019:博世相对高精度定位与千寻绝对高精度定位
  10. python gmm em算法 2维数据_AI大语音(六)——混合高斯模型(GMM)(深度解析)...