先按照起始值排序
class Solution {
public int[][] merge(int[][] intervals) {
//按照起始值排序
Arrays.sort(intervals, Comparator.comparingInt(i -> i[0]));
int [][] res=new int[intervals.length][2];
int setResIndex=-1;
for (int[] interval : intervals) {
if (setResIndex==-1||interval[0]>res[setResIndex][1]){
res[++setResIndex]=interval;
}else {
res[setResIndex][1]=Math.max(res[setResIndex][1],interval[1]);
}
}
return Arrays.copyOf(res,setResIndex+1);
}
}