hdu 1257 最少拦截系统 (贪心)
2015-09-21 15:57
309 查看
Problem Description
某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高度.某天,雷达捕捉到敌国的导弹来袭.由于该系统还在试用阶段,所以只有一套系统,因此有可能不能拦截所有的导弹.
怎么办呢?多搞几套系统呗!你说说倒蛮容易,成本呢?成本是个大问题啊.所以俺就到这里来求救了,请帮助计算一下最少需要多少套拦截系统.
Input
输入若干组数据.每组数据包括:导弹总个数(正整数),导弹依此飞来的高度(雷达给出的高度数据是不大于30000的正整数,用空格分隔)
Output
对应每组数据输出拦截所有导弹最少要配备多少套这种导弹拦截系统.
Sample Input
8 389 207 155 300 299 170 158 65
Sample Output
2
某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高度.某天,雷达捕捉到敌国的导弹来袭.由于该系统还在试用阶段,所以只有一套系统,因此有可能不能拦截所有的导弹.
怎么办呢?多搞几套系统呗!你说说倒蛮容易,成本呢?成本是个大问题啊.所以俺就到这里来求救了,请帮助计算一下最少需要多少套拦截系统.
Input
输入若干组数据.每组数据包括:导弹总个数(正整数),导弹依此飞来的高度(雷达给出的高度数据是不大于30000的正整数,用空格分隔)
Output
对应每组数据输出拦截所有导弹最少要配备多少套这种导弹拦截系统.
Sample Input
8 389 207 155 300 299 170 158 65
Sample Output
2
#include<stdio.h> int main() { int n,k,i,j; int flag; int h,a[1005]; while(~scanf ("%d",&n)) { k=1; scanf("%d",&h); a[0]=h;; for(i=1;i<n;i++) { flag=0; scanf("%d",&h); for(j=0;j<k;j++) { if(a[j]>h) { a[j]=h; flag=1; break; } } if(!flag) a[k++]=h; } printf("%d\n",k); } return 0; }
相关文章推荐
- 添加的千分的分隔符
- Tomcat下部署多个项目
- ocp-v13-683
- 添加千分的分隔符
- git 命令学习及更新
- 提高网页性能的九大技巧
- JAVA自带监控工具的介绍
- NET编程简易生成用友财务软件的财务接口数据
- Spring with Hibernate persistence and transactions example
- Android中常见的像素单位
- ubuntu 环境变量改错导致所有命令用不了
- 单例模式的七种写法
- android获取系统wifi状态等
- 解决ubuntu 14.04删ibus导致系统设置项目的损失后,,退出关机问题是不正常的
- 20150910程序包管理
- CAGradientLayer的使用
- SAP BO 学习地址
- 【springmvc+mybatis项目实战】杰信商贸-20.合同货物数和附件数
- 制作网页1---AWS 云主机+万网域名+XAMPP 配置自己的网站
- jsp页面间的传值方法