1. 程式人生 > >LeetCode 452. Minimum Number of Arrows to Burst Balloons & 435. Non-overlapping Intervals

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; }