题解 | #不重叠的身高#
不重叠的身高
https://www.nowcoder.com/practice/b11cb8804f5d4eb3b221a019efe3ad5f
import java.util.*;
public class Solution {
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param intervals int整型二维数组
* @return int整型二维数组
*/
public int[][] mergeAnimalRanges (int[][] intervals) {
// write code here
Arrays.sort(intervals, new Comparator<int[]>() { // 匿名内部类
@Override
public int compare(int[] e1, int[] e2) {
// 如果第一列元素相等,则比较第二列元素
if (e1[0]==e2[0]) return e1[1]-e2[1]; // e1[1]-e2[1]表示对于第二列元素进行升序排序
return e1[0]-e2[0]; // e1[0]-e2[0]表示对于第一列元素进行升序排序
}
});
List<Integer> temp=new ArrayList<>();
List<List<Integer>> ans=new ArrayList<>();
for (int i=1;i<intervals.length;i++){
if (intervals[i][0]<=intervals[i-1][1]&&intervals[i][0]>=intervals[i-1][0]){
intervals[i][0]=intervals[i-1][0];
if (intervals[i-1][1]>intervals[i][1]){
intervals[i][1]=intervals[i-1][1];
}
}else{
temp.add(intervals[i-1][0]);
temp.add(intervals[i-1][1]);
ans.add(new ArrayList<>(temp));
}
temp.clear();
}
temp.add(intervals[intervals.length-1][0]);
temp.add(intervals[intervals.length-1][1]);
ans.add(new ArrayList<>(temp));
int[][] tt = new int[ans.size()][];
for (int i = 0; i < ans.size(); i++) {
int[] arrays = ans.get(i).stream().filter(Objects::nonNull).mapToInt(j->j).toArray();
tt[i] = arrays;
}
return tt;
}
}
