思路
code
class Solution {public int eraseOverlapIntervals(int[][] intervals) {if(intervals.length==0)return 0;Arrays.sort(intervals, new Comparator<int[]>() {@Overridepublic int compare(int[] o1, int[] o2) {if (o1[1] != o2[1])return o1[1] - o2[1];return o1[0] - o2[0];}});//memo[i]表示intervals[0,,,i]区间能构成的最长不重叠区间序列int[] memo = new int[intervals.length];Arrays.fill(memo,1);for(int i =1;i<intervals.length;i++)for(int j=0;j<i;j++)if (intervals[i][0]>=intervals[j][1])memo[i] = Math.max(memo[i],1+memo[j]);int res = 0;for(int i:memo)res = Math.max(res,i);return intervals.length-res;}}
贪心
、
public int eraseOverlapIntervals(int[][] intervals) {if(intervals.length==0)return 0;Arrays.sort(intervals, new Comparator<int[]>() {@Overridepublic int compare(int[] o1, int[] o2) {if(o1[1]!=o2[1])return o1[1]-o2[1];return o1[0]-o2[0];}});int res = 1;int pre = 0;for(int i =1;i<intervals.length;i++)if(intervals[i][0]>=intervals[pre][1]){res++;pre=i;}return intervals.length-res;}
