LeetCode 452. Minimum Number of Arrows to Burst Balloons & 435. Non-overlapping Intervals
阿新 • • 發佈:2018-11-07
題解
兩題一起寫,都是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;
}