力扣经典150题第五十题:用最少数量的箭引爆气球

简介: 力扣经典150题第五十题:用最少数量的箭引爆气球

题目描述和要求

给定一些球形气球贴在一堵用 XY 平面表示的墙面上。墙面上的气球记录在整数数组 points 中,其中 points[i] = [xstart, xend] 表示水平直径在 xstart 和 xend 之间的气球。你不知道气球的确切 y 坐标。

一支弓箭可以沿着 x 轴从不同点完全垂直地射出。在坐标 x 处射出一支箭,若有一个气球的直径的开始和结束坐标为 xstart,xend,且满足 xstart ≤ x ≤ xend,则该气球会被引爆。可以射出的弓箭的数量没有限制。弓箭一旦被射出之后,可以无限地前进。

给你一个数组 points,返回引爆所有气球所必须射出的最小弓箭数。

示例解释

示例 1:

输入:points = [[10,16],[2,8],[1,6],[7,12]]

输出:2

解释:气球可以用2支箭来爆破:

  • 在x = 6处射出箭,击破气球[2,8]和[1,6]。
  • 在x = 11处发射箭,击破气球[10,16]和[7,12]。

示例 2:

输入:points = [[1,2],[3,4],[5,6],[7,8]]

输出:4

解释:每个气球需要射出一支箭,总共需要4支箭。

示例 3:

输入:points = [[1,2],[2,3],[3,4],[4,5]]

输出:2

解释:气球可以用2支箭来爆破:

  • 在x = 2处发射箭,击破气球[1,2]和[2,3]。
  • 在x = 4处射出箭,击破气球[3,4]和[4,5]。

解题思路

我们可以根据每个气球的起始坐标进行排序,然后遍历气球,如果当前气球的起始坐标大于前一个气球的结束坐标,则需要一支新的箭。具体步骤如下:

  1. 将气球按照起始坐标进行排序。
  2. 初始化箭的数量为1,初始化当前箭的射击位置为第一个气球的结束坐标。
  3. 遍历排序后的气球,如果当前气球的起始坐标大于当前箭的射击位置,则需要一支新的箭,并更新当前箭的射击位置为当前气球的结束坐标。
  4. 返回箭的数量。

算法实现

import java.util.Arrays;
public class MinArrowsBurstBalloons {
    public int findMinArrowShots(int[][] points) {
        if (points == null || points.length == 0) {
            return 0;
        }
        Arrays.sort(points, (a, b) -> Integer.compare(a[0], b[0]));
        int arrows = 1;
        int shootPos = points[0][1];
        for (int i = 1; i < points.length; i++) {
            if (points[i][0] > shootPos) {
                arrows++;
                shootPos = points[i][1];
            } else {
                shootPos = Math.min(shootPos, points[i][1]);
            }
        }
        return arrows;
    }
}

复杂度分析

  • 时间复杂度:O(nlogn),其中 n 为气球的数量。排序的时间复杂度为 O(nlogn),遍历一次气球的时间复杂度为 O(n)。
  • 空间复杂度:O(1),除了存储输入数组外,只需要常数级别的额外空间。

测试和验证

编写测试用例对算法进行验证,确保其正确性和健壮性。

public class Main {
    public static void main(String[] args) {
        MinArrowsBurstBalloons minArrowsBurstBalloons = new MinArrowsBurstBalloons();
        int[][] points1 = {{10,16},{2,8},{1,6},{7,12}};
        System.out.println(minArrowsBurstBalloons.findMinArrowShots(points1)); // 2
        int[][] points2 = {{1,2},{3,4},{5,6},{7,8}};
        System.out.println(minArrowsBurstBalloons.findMinArrowShots(points2)); // 4
        int[][] points3 = {{1,2},{2,3},{3,4},{4,5}};
        System.out.println(minArrowsBurstBalloons.findMinArrowShots(points3)); // 2
    }
}

总结和拓展

本题通过对气球按照起始坐标进行排序,并遍历气球的方式,实现了求解引爆所有气球所必须射出的最小弓箭数。这个算法思路清晰简单,在处理类似问题时是一个不错的选择。

此外,我们也可以考虑其他实现方式,例如使用贪心算法或动态规划等方法来解决类似问题。

参考资料

  • 《力扣经典150题》
  • LeetCode 官方网站
相关文章
|
网络协议 安全 Android开发
软件丨李跳跳们现在该如何跳呢?
前段时间,李跳跳等软件被某大厂发了律师函,之后,好些个跳广告软件都相继发布公众号说明,停止维护软件,并且下架了相关软件,那我们还能跳吗?该怎么跳呢?
1546 0
软件丨李跳跳们现在该如何跳呢?
|
缓存 NoSQL 数据库
2023春招面试专题:高并发解决方案
2023春招面试专题:高并发解决方案
217 0
|
9月前
|
安全 前端开发 Android开发
拥抱国产化:转转APP的鸿蒙NEXT端开发尝鲜之旅
本文将要分享的是转转APP在开发全新鸿蒙NEXT端所遇到的一些问题,对比了鸿蒙开发和 Android、iOS 的不同,总结了这次开发过程中的一些经验等等。希望能带给你启发。
553 0
|
JavaScript Java 测试技术
基于ssm+vue.js的公司人力资源管理系统附带文章和源代码设计说明文档ppt
基于ssm+vue.js的公司人力资源管理系统附带文章和源代码设计说明文档ppt
124 1
|
存储 缓存 弹性计算
阿里云服务器通用型g5、g6、g7实例区别及选择参考
在我们选择阿里云服务器实例规格的时候,如果是选择通用型实例,会发现同样是通用型实例,有通用型g5、通用型g6和通用型g7可选(当然还有g8i、g8y等其他通用型实例可选),他们都属于企业级云服务器,都配有2核4G、4核8G和8核16G等处理器与内存比1:4的配置,那么它们之间有什么区别,下边就这三个实例各自的特点、网络、适用场景及最新活动价格来详细分析一下新手用户应该怎么选择。
阿里云服务器通用型g5、g6、g7实例区别及选择参考
|
中间件 测试技术 调度
设计一个简易版本的分布式任务调度系统
设计一个简易版本的分布式任务调度系统
386 0
|
Ubuntu Linux Android开发
百度搜索:【蓝易云】 Termux安装完整版Linux(Ubuntu)详细步骤
Termux是一款在Android系统上运行的终端模拟器,可以让用户在手机上运行Linux命令行工具和应用程序。本文将介绍如何在Termux中安装完整版Linux(Ubuntu)。
569 1
|
Java Spring
SpringBoot升级3.0方法
升级到新功能版本时,某些属性可能已被重命名或删除。
【GO】使用GoLand编辑器开发写的代码自动对齐
【GO】使用GoLand编辑器开发写的代码自动对齐
669 0
【GO】使用GoLand编辑器开发写的代码自动对齐
|
Scala 开发者 Kotlin
Map 的四种取值方式 | 学习笔记
快速学习 Map 的四种取值方式