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

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/smmyy022/article/details/83239645

题解

两题一起写,都是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;
    }

猜你喜欢

转载自blog.csdn.net/smmyy022/article/details/83239645
今日推荐