【面试经典150 | 区间】用最少数量的箭引爆气球

文章目录

Tag

【合并区间】【排序】【数组】


题目来源

452. 用最少数量的箭引爆气球


题目解读

每个气球都有一个占据x轴的一个范围,在这个范围里射出一只箭就会引爆该气球,现在有一堆排布好的气球,试问引爆所有的气球至少需要多少支箭。


解题思路

方法一:合并区间

气球都是以区间的形式给出的,那么我们将有交集的区间进行合并,然后剩下的区间每个区间都需要一只箭来引爆q

实现代码

cpp 复制代码
class Solution {
public:
    int findMinArrowShots(vector<vector<int>>& points) {
        int res = 1;
        sort(points.begin(), points.end());
        int r = points[0][1];
        for (int i = 1; i < points.size(); ++i) {
            if (points[i][0] > r) {
                ++res;
            }
            else {
                points[i][0] = max(points[i-1][0], points[i][0]);
                points[i][1] = min(points[i-1][1], points[i][1]);
            }
            r = points[i][1];
        }
        return res;
    }
};

复杂度分析

时间复杂度: O ( n l o g n ) O(nlogn) O(nlogn), n n n 为数组 points 的长度。

空间复杂度: O ( n l o g n ) O(nlogn) O(nlogn),额外的空间是排序占据的空间。


其他语言

python3

合并区间

python3 复制代码
class Solution:
    def findMinArrowShots(self, points: List[List[int]]) -> int:
        points.sort()

        r = points[0][1]
        n = len(points)
        res = 1
        for i in range(1, n):
            if points[i][0] > r:
                res += 1
            else:
                points[i][0] = max(points[i-1][0], points[i][0])
                points[i][1] = min(points[i-1][1], points[i][1])
            r = points[i][1]
        return res

写在最后

如果文章内容有任何错误或者您对文章有任何疑问,欢迎私信博主或者在评论区指出 💬💬💬。

如果大家有更优的时间、空间复杂度方法,欢迎评论区交流。

最后,感谢您的阅读,如果感到有所收获的话可以给博主点一个 👍 哦。

相关推荐
汀、人工智能1 天前
[特殊字符] 第78课:乘积最大子数组
数据结构·算法·数据库架构·数组·前缀积·乘积最大子数组
起个破名想半天了3 天前
算法与数据结构之排序
数据结构·排序算法·排序·算法与数据结构
圣光SG3 天前
数据结构通用笔记(语言无关)
数据结构·学习·链表·数组··队列
汀、人工智能4 天前
[特殊字符] 第105课:除自身以外数组的乘积
数据结构·算法·数据库架构·数组·前缀积·除自身以外数组的乘积
Byte不洛9 天前
LeetCode中经典双指针题(环形链表 + 快乐数 + 移动零)
算法·leetcode·链表·数组·双指针
Q741_14710 天前
每日一题 力扣 2840. 判断通过操作能否让字符串相等 II 力扣 2839. 判断通过操作能否让字符串相等 I 找规律 字符串 C++ 题解
c++·算法·leetcode·力扣·数组·找规律
问好眼11 天前
《算法竞赛进阶指南》0x05 排序-1.电影
c++·算法·排序·信息学奥赛
烛衔溟11 天前
TypeScript 基础类型(下):数组、元组与枚举
typescript·前端开发·枚举·数组·元组
2301_8227828212 天前
C语言数组通关攻略!从一维到字符数组,零基础也能轻松掌握
c语言·算法·数组·编程基础·避坑技巧
Q741_14713 天前
每日一题 力扣 2946. 循环移位后的矩阵相似检查 力扣 155. 最小栈 数学 数组 模拟 C++ 题解
c++·算法·leetcode·矩阵·模拟·数组·