HDOJ 1257 最少拦截系统
2015-07-20 09:34
302 查看
最少拦截系统
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 25348 Accepted Submission(s): 9960
[align=left]Problem Description[/align]
某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高度.某天,雷达捕捉到敌国的导弹来袭.由于该系统还在试用阶段,所以只有一套系统,因此有可能不能拦截所有的导弹.
怎么办呢?多搞几套系统呗!你说说倒蛮容易,成本呢?成本是个大问题啊.所以俺就到这里来求救了,请帮助计算一下最少需要多少套拦截系统.
[align=left]Input[/align]
输入若干组数据.每组数据包括:导弹总个数(正整数),导弹依此飞来的高度(雷达给出的高度数据是不大于30000的正整数,用空格分隔)
[align=left]Output[/align]
对应每组数据输出拦截所有导弹最少要配备多少套这种导弹拦截系统.
[align=left]Sample Input[/align]
8 389 207 155 300 299 170 158 65
[align=left]Sample Output[/align]
2
[align=left]Source[/align]
浙江工业大学第四届大学生程序设计竞赛
[align=left]Recommend[/align]
JGShining | We have carefully selected several similar problems for you: 1176 1003 1159 1087 1231
思路:来第一个导弹开始使用第一个拦截系统,再来导弹,判断之前的拦截系统能否拦截,若能,判断下一导弹,若不能,再搞一套拦截系统。
#include<stdio.h> #include<string.h> int main(){ int n,i,j,k,a[1000],b[1000];//a为来的导弹高度,b为能打下来的导弹高度 while(scanf("%d",&n)!=EOF){ k=0; scanf("%d",&a[0]); b[k]=a[0]; for(i=1;i<n;i++){ scanf("%d",&a[i]); for(j=0;j<=k;j++) if(b[j]>a[i]){ b[j]=a[i]; break; }//能使用的拦截高度大于来的导弹高度 if(j>k) b[++k]=a[i];//能使用的导弹在其之后出现,就另搞一个拦截系统 } printf("%d\n",k+1); } return 0; }
相关文章推荐
- FineReport搭建物流报表平台的解决方案
- MySQL(1):启动MySQL服务,客户端连接服务
- <a>标签中href和onclick传递this对象的实现方法
- 使用Genymotion调试出现错误INSTALL_FAILED_CPU_ABI_INCOMPATIBLE解决办法
- redis常用命令
- Android快速开发不可或缺的11个工具类
- android---手电筒之摩尔斯电码
- LeeCode-Two Sum
- Django框架中处理URLconf中特定的URL的方法
- Linux C函数使用记录
- Mac/Windows/Linux安装MYSQL
- Google Java编程风格指南中文版
- Linux下使用多个不同版本的R
- spring mvc +extjs 学习
- LeeCode-Rotate Array
- Fix “Could Not Find This Item” When Deleting in Windows 7
- 【从零单排之微软面试100题系列】13之输出链表倒数第k个结点
- HDU1396:Counting Triangles -DP
- ruby设计模式学习笔记 (一)
- 7.20 HTML表单(form)标签、单选、复选