leetcode力扣——452. 用最少数量的箭引爆气球

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

目录

题目

思路:

代码


题目

要求:

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

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

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

示例:

以防有人看不懂的,找到了这张图(其实就是找有多少个气球的位置有重叠):

来自:一头小蜗牛的分享

思路:

这种讨论有没有位置重叠的,一般先给它排序。

排序完,咋解决呢?

举个栗子(本来应该用闭括号的,感觉看着不太清晰,这里用开括号了):

(0,6)(0,9)(2,9)(3,8)(3,9)(6,8)(7,12)(9,10)

哪几个气球位置有重叠呢?

两个:

(0,6) (7,12)

(0,9) (9,10)

(2,9)

(3,8)

(3,9)

(6,8)

左边这列:射击6就能将六个气球包圆,右边这列射击 9到10 都能把两个气球包圆

然后我们看左边这列,其实把(6,8)这个位置拿走,射击 3到6 都能把五个气球包圆,那么对于(3,6)加入(6,8)--> (6,6),其实就是收缩了区间可以理解为,取公共子集。


咋求公共子集:

  • 引入一个 left 和 right (int 类型)------用于保存公共子集的边界
cpp 复制代码
            if(points[i][0] >= left && points[i][0] <= right)
            {
                //收缩(求公共子集)
                left = max(left, points[i][0]);
                right = min(right, points[i][1]);
            }

代码

依照取得公共子集的逻辑,不难得到以下实现:

cpp 复制代码
class Solution
{
public:
    int findMinArrowShots(vector<vector<int>>& points)
    {
        int res = 1;
        //排序
        sort(points.begin(), points.end(), [](const vector<int> &a, const vector<int> &b)
        {return a[0] < b[0]; } );

        //统计
        int left = points[0][0], right = points[0][1];
        for(int i = 1; i < points.size(); i++)
        {
            //看受否将其包含在内
            if(points[i][0] >= left && points[i][0] <= right)
            {
                //收缩(求公共子集)
                left = max(left, points[i][0]);
                right = min(right, points[i][1]);
            }
            else
            {
                res++;
                //求下一个公共子集
                left = points[i][0];
                right = points[i][1];
            }
        }
        return res;
    }
};
相关推荐
lilihuigz20 小时前
Tutor LMS 4.0 Beta版全新上线:以学习者为中心的移动优先学习体验
学习·在线教育·lms
王老师青少年编程21 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮21 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说21 小时前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
wuweijianlove1 天前
关于算法设计中的代价函数优化与约束求解的技术7
算法
小程故事多_801 天前
[大模型面试系列] 多轮对话 Agent 设计实战(含窗口优化 + 工具调用精髓)
人工智能·面试·职场和发展
leoufung1 天前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了1 天前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
HXDGCL1 天前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化
谭欣辰1 天前
C++ 排列组合完整指南
开发语言·c++·算法