NYOJ79,拦截导弹

2024-06-12 07:08
文章标签 nyoj79 拦截导弹

本文主要是介绍NYOJ79,拦截导弹,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

拦截导弹

时间限制: 3000 ms  |  内存限制: 65535 KB
难度: 3
描述

某国为了防御敌国的导弹袭击,发展中一种导弹拦截系统。但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能高于等于前一发的高度。某天,雷达捕捉到敌国导弹来袭。由于该系统还在试用阶段,所以只用一套系统,因此有可能不能拦截所有的导弹。

输入
第一行输入测试数据组数N(1<=N<=10)
接下来一行输入这组测试数据共有多少个导弹m(1<=m<=20)
接下来行输入导弹依次飞来的高度,所有高度值均是大于0的正整数。
输出
输出最多能拦截的导弹数目
样例输入
2
8
389 207 155 300 299 170 158 65
3
88 34 65
样例输出
6
2
来源
[张洁烽]原创

经典的动态规划,最长下降子序列


import java.io.BufferedInputStream;
import java.util.Arrays;
import java.util.Scanner;public class NYOJ79_ieayoio {public static void main(String[] args) {Scanner cin = new Scanner(new BufferedInputStream(System.in));int t = cin.nextInt();while (t-- > 0) {int n = cin.nextInt();int[] a = new int[n + 5];for (int i = 1; i <= n; i++) {a[i] = cin.nextInt();}int[] f = new int[n + 5];Arrays.fill(f, 1);f[1] = 1;for (int i = 2; i <= n; i++) {// f[i]=f[i-1];for (int j = 1; j <= i - 1; j++) {if (a[i] < a[j] && f[i] < f[j] + 1) {f[i] = f[j] + 1;}}}int max = Integer.MIN_VALUE;for (int i = 1; i <= n; i++)if (max < f[i])max = f[i];System.out.println(max);}}}









这篇关于NYOJ79,拦截导弹的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1053521

相关文章

NYOJ 79 拦截导弹(dp)

时间限制:3000 ms  |  内存限制:65535 KB 难度: 3 描述 某国为了防御敌国的导弹袭击,发展中一种导弹拦截系统。但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能高于等于前一发的高度。某天,雷达捕捉到敌国导弹来袭。由于该系统还在试用阶段,所以只用一套系统,因此有可能不能拦截所有的导弹。 输入 第一

nyoj-79-拦截导弹

1.第一个元素存入数组     2.第二个进入时与第一个比较,若小于第一个元素,存入数组的尾部。若大于第一个元素,则覆盖第一个元素(核心步骤:提高最长单调递减序列的上界,使更多的元素进入此序列)。         3.第三个元素,与第一个元素比较,若小于,与第二个元素比较,若小于,存入数组的尾部。若大于第一个或者第二个元素,则覆盖该元素。

秋招算法——AcWing101——拦截导弹

文章目录 题目描述思路分析实现源码分析总结 题目描述 思路分析 目前是有一个笨办法,就是创建链表记录每一个最长下降子序列所对应的节点的链接,然后逐个记录所有结点的访问情况,直接所有节点都被访问过。这个方法不是很好,因为需要计算很多次,会超时,这里用了贪心的方法来证明,虽然不是最优子序列,但是数量是一致的。 实现源码 #include <iostream>#inc

【例6.4】拦截导弹问题(Noip1999)

这个问题可以使用动态规划来解决。我们需要找到最小的系统数量,以拦截所有导弹。每一套系统都需要满足条件:第一发炮弹能够到达任意的高度,但之后每一发炮弹的高度都不能超过前一发。 我们可以使用两个数组:dp1 和 dp2。dp1[i] 表示拦截前 i 个导弹所需的最少系统数,并且考虑第 i 个导弹作为新的一套系统的最高点。dp2[i] 则表示拦截前 i 个导弹时,最后一个系统的最高点所能达到的最大高度

题目 2123: T1260-拦截导弹

题目描述: 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统。但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能高于前一发的高度。某天,雷达捕捉到敌国的导弹来袭。由于该系统还在试用阶段,所以只有一套系统,因此有可能不能拦截所有的导弹。 输入导弹依次飞来的高度(雷达给出的高度数据是不大于30000的正整数,导弹数不超过1000),计算这套系统最多能拦截

nyoj814又见拦截导弹

又见拦截导弹 时间限制: 3000 ms  |  内存限制: 65535 KB 难度: 3 描述 大家对拦截导弹那个题目应该比较熟悉了,我再叙述一下题意:某国为了防御敌国的导弹袭击,新研制出来一种导弹拦截系统。但是这种导弹拦截系统有一个缺陷:它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高度。突然有一天,雷达捕捉到敌国的导弹来袭。由于该系统存在缺

蓝桥杯 拦截导弹 动态规划(最长下降子序列+最长上升子序列)

算法训练 拦截导弹   时间限制:1.0s   内存限制:256.0MB         问题描述 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统。但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能高于前一发的高度。某天,雷达捕捉到敌国的导弹来袭。由于该系统还在试用阶段,所以只有一套系统,因此有可能不能拦截所有的导弹。

【算法】拦截导弹(线性DP)

题目  某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统。 但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能高于前一发的高度。 某天,雷达捕捉到敌国的导弹来袭。 由于该系统还在试用阶段,所以只有一套系统,因此有可能不能拦截所有的导弹。 输入导弹依次飞来的高度(雷达给出的高度数据是不大于30000的正整数,导弹数不超过1000),计算这套系统

信息学奥赛第十节 —— 贪心算法(渡河问题POJ 1700 Crossing River + 拦截导弹的系统数量求解)

复习概念 贪心算法又叫贪婪算法,是指在对问题求解时,总是做出在当前看来是最好的选择。也就是说,贪心算法不从整体最优上加以考虑,它所做出的是在某种意义上的局部最优解。 无后效性:贪心算法不是对所有问题都能得到整体最优解,关键是贪心策略的选择,选择的贪心策略必须具备无后效性,即某个状态以前的过程不会影响以后的状态,只与当前状态有关。 贪心算法使用的前提:局部最优解一定能导致全局最优解。 贪心算法的

012:拦截导弹

012:拦截导弹 描述 某国为了防御敌国的导弹袭击,开发出一种导弹拦截系统。但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能高于前一发的高度。某天,雷达捕捉到敌国的导弹来袭,并观测到导弹依次飞来的高度,请计算这套系统最多能拦截多少导弹。拦截来袭导弹时,必须按来袭导弹袭击的时间顺序,不允许先拦截后面的导弹,再拦截前面的导弹。 输入 输入有两行,