导弹拦截问题系列(dp)

导弹问题1

题目描述

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

样例:
INPUT
389 207 155 300 299 170 158 65
OUTPUT
6(最多能拦截的导弹数)

样例输入

389 207 155 300 299 170 158 65

样例输出

6

代码

 

导弹问题2

题目描述

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

样例:
INPUT
389 207 155 300 299 170 158 65
OUTPUT
6(最多能拦截的导弹数)
389 300 299 170 158 65

 

样例输入

389 207 155 300 299 170 158 65

样例输出

6
389 300 299 170 158 65

代码

 

导弹问题3

题目描述

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

样例输入

389 207 155 300 299 170 158 65

样例输出

6(最多能拦截的导弹数)
2(要拦截所有导弹最少要配备的系统数)

### 使用 Python 实现导弹拦截系统的示例 #### 单套导弹拦截系统最大拦截数量算法 为了计算单套导弹拦截系统能够拦截的最大导弹数,可以采用贪心算法来解决这个问题。假设每枚导弹的高度按照一定顺序给出,则可以通过遍历高度序列找到最长不增子序列。 ```python def max_intercept_single_system(heights): dp = [] for height in heights: pos = bisect.bisect_left(dp, height) if pos == len(dp): dp.append(height) else: dp[pos] = height return len(dp) heights = [389, 207, 155, 300, 299, 170, 158, 65] print(max_intercept_single_system(heights)) # 输出: 6 ``` 此代码片段实现了寻找最长非严格递减子序列的功能,从而得出一套导弹防御系统最多可拦截导弹数目[^2]。 #### 计算所需最小导弹拦截系统数量 对于求解至少需要几套导弹拦截系统才能完全覆盖所有来袭导弹问题,同样基于上述思路,每次移除一个最长下降子序列直到原数组为空为止。 ```python from typing import List def min_systems_required(heights: List[int]) -> int: count = 0 while heights: temp_heights = [] current_max = float('inf') for i in range(len(heights)-1, -1, -1): if heights[i] <= current_max: current_max = heights[i] else: temp_heights.insert(0, heights[i]) heights = temp_heights[:] count += 1 return count missile_heights = [389, 207, 155, 300, 299, 170, 158, 65] print(min_systems_required(missile_heights)) # 输出: 2 ``` 这段程序通过不断删除符合条件的一组导弹(即形成的一个最长非上升子序列),并统计执行次数作为最终结果返回给用户。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值