博客
关于我
导弹打飞机问题(贪心算法)
阅读量:502 次
发布时间:2019-03-07

本文共 930 字,大约阅读时间需要 3 分钟。

为了解决这个问题,我们需要计算在给定飞机各自的高度情况下,最少需要配备多少套防空导弹系统。每个系统只能拦截飞机的高度递减的情况。

方法思路

我们可以使用贪心算法来解决这个问题。每次处理一个新的飞机高度时,我们检查现有的系统是否能继续拦截该飞机。如果能,选择最合适的系统并更新其最低高度;如果不能,新建一个系统。这种方法确保了每一步做出局部最优选择,从而得到全局最优解。

具体步骤如下:

  • 读取输入的飞机数量和每架飞机的高度。
  • 初始化一个数组 b,记录每个系统的最低高度,索引从1开始。
  • 遍历每架飞机的高度,检查现有系统中是否有能拦截的系统。
  • 如果存在,选择最大的系统并更新其最低高度;如果不存在,新建一个系统。
  • 最终,系统的数量即为所求。
  • 解决代码

    n = int(input())a = [int(input()) for _ in range(n)]if n == 0:    print(0)    exit()b = [0]  # b[1]开始使用b[1] = a[0]k = 1for i in range(1, n):    x = 0    for j in range(1, k + 1):        if b[j] >= a[i]:            if x == 0:                x = j            else:                if b[x] > b[j]:                    x = j    if x == 0:        k += 1        b.append(a[i])    else:        b[x] = a[i]print(k)

    代码解释

  • 读取输入:首先读取飞机的数量 n 和每架飞机的高度数组 a
  • 初始化数组:创建数组 b 来记录每个系统的最低高度,索引从1开始,初始值为0。
  • 处理每架飞机:遍历每架飞机的高度,检查现有系统中是否有能拦截的系统。如果有,选择最大的系统并更新其最低高度;如果没有,新建一个系统。
  • 输出结果:最终输出所需的系统数量 k
  • 这种方法确保了我们在每一步都做出最优选择,从而在最少的系统数下拦截所有飞机。

    转载地址:http://opjcz.baihongyu.com/

    你可能感兴趣的文章
    nginx + etcd 动态负载均衡实践(二)—— 组件安装
    查看>>
    nginx + etcd 动态负载均衡实践(四)—— 基于confd实现
    查看>>
    Nginx + Spring Boot 实现负载均衡
    查看>>
    Nginx + uWSGI + Flask + Vhost
    查看>>
    Nginx - Header详解
    查看>>
    Nginx Location配置总结
    查看>>
    Nginx upstream性能优化
    查看>>
    Nginx 中解决跨域问题
    查看>>
    Nginx 动静分离与负载均衡的实现
    查看>>
    Nginx 反向代理 MinIO 及 ruoyi-vue-pro 配置 MinIO 详解
    查看>>
    Nginx 反向代理解决跨域问题
    查看>>
    Nginx 反向代理配置去除前缀
    查看>>
    nginx 后端获取真实ip
    查看>>
    Nginx 学习总结(17)—— 8 个免费开源 Nginx 管理系统,轻松管理 Nginx 站点配置
    查看>>
    nginx 常用配置记录
    查看>>
    Nginx 我们必须知道的那些事
    查看>>
    Nginx 的 proxy_pass 使用简介
    查看>>
    Nginx 的配置文件中的 keepalive 介绍
    查看>>
    Nginx 负载均衡与权重配置解析
    查看>>
    Nginx 负载均衡详解
    查看>>