56.合并区间
class Solution {
public int[][] merge(int[][] intervals) {
/**
1.根据元素左侧的大小排序。
2.判断合并
a.如果下一个元素的左侧元素大于当前元素的右侧元素,不合并,直接加入。
b.如果不是,进行合并,将当前元素的右侧元素和下一元素的右侧元素比较大小,去较大值为右侧元素。左侧元素不变。
*/
if(intervals.length==0){
return new int[0][2];
}
Arrays.sort(intervals,new Comparator<int[]>() {
public int compare(int[] interval1,int[] interval2){
return interval1[0]-interval2[0];
}
});
// 存储最终结果
List<int[]> merged = new ArrayList<int[]>();
for(int i =0; i < intervals.length;i++){
int L = intervals[i][0],R = intervals[i][1];
if(merged.size()==0||merged.get(merged.size() - 1)[1] < L){
merged.add(new int[]{L,R});
}else{
merged.get(merged.size()-1)[1] = Math.max(merged.get(merged.size()-1)[1],R);
}
}
return merged.toArray(new int[merged.size()][]);
}
}
作者:静默虚空
欢迎任何形式的转载,但请务必注明出处。
限于本人水平,如果文章和代码有表述不当之处,还请不吝赐教。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)