• 力扣452-用最少数量的箭引爆气球——贪心算法


    题目描述

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

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

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

    解题思路

    这道题属于重复区间判断,与上一道题目非常相似。解题思路和他是一致的:首先对各个自区间进行排序,通过区间尾和下一个区间头对比,判断两个区间是否有重叠,如果当前区间尾大于等于下个区间头,说明俩区间有重叠,更新区间尾min(当前区间尾,下个区间尾);反之则没有重叠,区间尾更新为下个区间尾。

    435题意图是找出重复区间的个数,这道题目则是相反,找的是不重叠区间的个数,因为在重复的区间内,必然会引爆重复区间的气球,只需要一把弓箭,而区间不重复,弓箭数量才会更新+1。力扣435-无重复区间icon-default.png?t=M5H6https://blog.csdn.net/weixin_44564247/article/details/125627545

     对于数组排序

    Arrays.sort(points, (o1,o2)->(o1[1]-o2[1]));

     发现按照上面这种排序方式,示例

    [[-2147483646,-2147483645],[2147483646,2147483647]]无法通过测试,debug之后发现,这种排序方式会判断成为负数 -2147483646 > 正数 2147483646 ,并不能通过所有测试用例。

     Arrays.sort(points, Comparator.comparingInt(o -> o[1]));

     这种写法可以对二维数组按照指定的维度排序,这里换成 o[0] 也是可以的。 

    输入输出示例

     

    代码

    1. class Solution {
    2. public int findMinArrowShots(int[][] points) {
    3. Arrays.sort(points, Comparator.comparingInt(o -> o[1]));
    4. //Arrays.sort(points, (o1,o2)->(o1[1]-o2[1]));
    5. int res = 1;
    6. long end = points[0][1];
    7. for(int i = 1;i<points.length;i++){
    8. if(end >= points[i][0]){
    9. end = Math.min(end,points[i][1]);
    10. }else{
    11. end = points[i][1];
    12. res++;
    13. }
    14. }
    15. return res;
    16. }
    17. }

  • 相关阅读:
    IDEA为什么不能搜索到jar里的代码?
    Golang一日一库之 日志库 zap
    Haddop+Hive 单机hadoop 单机hive
    No Monotone Triples
    泡泡玛特城市乐园开园在即,知名潮玩IP落地北京朝阳
    vue3组件篇 Breadcrum
    量子力学的应用:量子计算
    Lazada跨境电商API接口,Onebound数据
    【算法】Reverse Integer
    通过浏览器F12开发者工具的javascript控制台给Vue表单赋值
  • 原文地址:https://blog.csdn.net/weixin_44564247/article/details/125632737