简单贪心,但理解题意真的很重要
正确的理解是 在开启第多套拦截系统后 后面飞来的导弹还可以用前面的拦截系统进行拦截 贪心的话 只需要每次选择当前拦截高度最低的那套系统去拦就好了
测试数据
8 389 207 155 300 299 170 158 65
2
8 389 207 158 300 299 170 155 156
2
8 300 4 298 3 297 2 296 1
2
代码:
/**
*
*/
/**
* @author Enron
*
*/
package _1257;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Scanner;
public class Main{
public static void main(String [] args){
Scanner sc = new Scanner(System.in);
while(sc.hasNext()){
int n = sc.nextInt();
ArrayList<Integer> lowH = new ArrayList<Integer>();
boolean isFir = true;
while((n--)!=0){
int x = sc.nextInt();
boolean hasGo = false; //导弹是否被拦下来
if(isFir) {
lowH.add(x);
isFir = false;
}
for (int i = 0; i < lowH.size(); i++) {
if(x<=lowH.get(i)){
lowH.set(i, x);
hasGo = true;
break;
}
}
if(!hasGo){
lowH.add(x);
}
Collections.sort(lowH); //从小到大 贪心 每次用最低的拦
}
System.out.println(lowH.size());
}
}
}
最少拦截系统
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 47186 Accepted Submission(s): 18514
Problem Description
某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高度.某天,雷达捕捉到敌国的导弹来袭.由于该系统还在试用阶段,所以只有一套系统,因此有可能不能拦截所有的导弹.
怎么办呢?多搞几套系统呗!你说说倒蛮容易,成本呢?成本是个大问题啊.所以俺就到这里来求救了,请帮助计算一下最少需要多少套拦截系统.
怎么办呢?多搞几套系统呗!你说说倒蛮容易,成本呢?成本是个大问题啊.所以俺就到这里来求救了,请帮助计算一下最少需要多少套拦截系统.
Input
输入若干组数据.每组数据包括:导弹总个数(正整数),导弹依此飞来的高度(雷达给出的高度数据是不大于30000的正整数,用空格分隔)
Output
对应每组数据输出拦截所有导弹最少要配备多少套这种导弹拦截系统.
Sample Input
8 389 207 155 300 299 170 158 65
Sample Output
2
Source
Recommend
JGShining