题目链接:https://leetcode-cn.com/problems/non-overlapping-intervals/submissions/
刚做完一道区间的题,又随机刷出来一道区间的题,那么和上一道(上一篇博客)那道题大同小异,我们考虑一下如果两个区间有重叠,那么一定是要删除一个的,那么删除哪一个就需要进行比较了,首先我们按照区间的左端点进行排序。遍历区间,如果相邻的两个区间重叠了,那么最优的删除就是看谁的右端点最靠右,不难想到越是靠右就越有可能覆盖到后面的区间,所以按照这个思路删除就好了。
AC代码:
class Solution {
public:
int eraseOverlapIntervals(vector<vector<int>>& intervals) {
int ans = 0;
int len = intervals.size();
if(len == 0) return 0;
sort(intervals.begin(), intervals.end(),[](vector<int>& a,vector<int>& b){
return a[0] < b[0];
});
int x = intervals[0][0], y = intervals[0][1];
for(int i=1;i<len;i++){
if(y > intervals[i][0]){
if(y > intervals[i][1]){
x = intervals[i][0];
y = intervals[i][1];
ans ++;
}
else{
ans ++;
}
}
else{
x = intervals[i][0];
y = intervals[i][1];
}
}
return ans;
}
};