贪心算法关键点加力扣452用最少数量的箭引爆气球解析

文章介绍了如何使用贪心算法解决LeetCode问题452,即在给定区域内用最少的箭引爆气球。通过先排序气球,然后确定每个气球是否在已引爆区间的边界内,逐步扩大有效范围,找到最小箭数解。
摘要由CSDN通过智能技术生成

1.当遇到多个条件需要考虑的时候,一定、一定、一定要先考虑其中一个条件,然后再考虑下一个条件,否则很容易两边都顾不上。

2.不论时刷题还是面试的时候,手动模拟一下感觉可以局部最优推出整体最优,而且想不到反例,那么就试一试贪心,软件不想硬件,软件没有试错成本,想到了就可以去干,即使错了也就是找到了一种不适合这道题的方法,数学推导并不在我们需要考虑的范围内。

力扣452用最少数量的箭引爆气球解析:

题目的意思可以理解为:在x轴正方向与y轴正方向之间的区间内有一定数量的气球,从x轴某一点沿y轴方向射出一支箭,如果该箭射出位置在气球所在范围内则可以引爆该气球,求最少使用的箭数。(气球y坐标不知道,意思是气球在y轴方向是可以重叠的)

思路:使用最少的箭数,就是每箭引爆相对更多的气球,为什么不是绝对更多的呢,因为如果按照绝对更多,那么假设总共有6个气球,中间重叠区域有4个气球,左边重叠三个,右边重叠三个,如果先射中间,那么需要3箭,如果左右各射一箭,那么只需要两箭。

解析:将气球的初始位置按照从小到大的顺序排序,设左端点l为第一个气球的开始位置,右端点r为第一个气球结束位置,在l与r组成的区间内是必须射一箭的。设使用箭数res初始为1,从第二个气球开始遍历,判断左端点是否在l和r组成的区间内,如果在,那么左区间取原来的l值和当前遍历气球的左端点的最大值,右区间取原来r值和当前遍历起球右端点的最小值;如果不在,那么l等于当前气球开始点,r等于当前气球结束点,使用箭数res加一。

附代码:

        var findMinArrowShots = function (points) {
            points.sort((a, b) => a[0] - b[0])//将气球按照初始位置排序,不考虑结束位置
            let res = 1, l = points[0][0], r = points[0][1]
            for (let i = 1; i < points.length; i++) {
                if (points[i][0] <= r && points[i][0] >= l) {//如果本气球开始位置在区间内,那么就重新取最小区间,
                    l = Math.max(l, points[i][0])
                    r = Math.min(r, points[i][1])
                } else {//如果本气球不在区间里,让左右区间变成本气球所在区间,使用箭数加一
                    res++
                    l = points[i][0]
                    r = points[i][1]
                }
            }
            return res
        };
  • 9
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值