435. 无重叠区间(思维)
- 2020 年 2 月 17 日
- 筆記
题目链接: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; } };