LeetCode 452. Minimum Number of Arrows to Burst Balloons & 435. Non-overlapping Intervals

题解

两题一起写,都是pair型数组,都考虑交叠问题,都是贪心。
这类题的核心都在于预先sort一下,以second升序排(若相等再以first升序)。
这样的好处是,我们再顺序遍历的时候可以很方便地发现交叠情况:
比如用一个 p 变量记载之前的second,新位置比较一下first就知道是否相交。


Code

452

int findMinArrowShots(vector<pair<int, int>>& points) {
        sort(points.begin(),points.end(),[](pair<int, int> &a,pair<int, int>&b){
            return a.second == b.second? a.first<b.first:a.second<b.second;
        });
        
        int pos=-9999999,ans=0;;
        for(auto p:points){
            if( pos!=-9999999&&pos>=p.first) continue;
            pos = p.second;
            ans++;
        }
        return ans;
    }

435

int eraseOverlapIntervals(vector<Interval>& intervals) {
        sort(intervals.begin(),intervals.end(),[](Interval &a,Interval &b){
            return a.end == b.end? a.start<b.start:a.end<b.end;
        });
        int pos=-99999999,ans=0;
        for(auto itv: intervals){
            if(pos==-99999999) {
                pos=itv.end;
                continue;
            }
            if(itv.start<pos){
                ans++;
            }else{
                pos=itv.end;
            }
        }
        return ans;
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值