版权声明:本文为博主原创文章,未经博主允许不得转载。 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;
}