贪心
import java.util.Arrays;
import java.util.Comparator;
import java.util.LinkedList;
class Solution {
public int[][] merge(int[][] intervals) {
Arrays.sort(intervals, new Comparator<int[]>() {
@Override
public int compare(int[] o1, int[] o2) {
return o1[0] - o2[0];
}
});
LinkedList<int[]> list = new LinkedList<>();
list.add(new int[]{intervals[0][0], intervals[0][1]});
for (int i = 1; i < intervals.length; i++) {
int[] temp = list.getLast();
if (intervals[i][0] <= temp[1]){
list.removeLast();
list.add(new int[]{Math.min(temp[0], intervals[i][0]), Math.max(temp[1], intervals[i][1])});
}
else{
list.add(new int[]{intervals[i][0], intervals[i][1]});
}
}
return list.toArray(new int[list.size()][]);
}
}
优化1——原地更新区间边界
import java.util.Arrays;
import java.util.Comparator;
import java.util.LinkedList;
class Solution {
public int[][] merge(int[][] intervals) {
Arrays.sort(intervals, new Comparator<int[]>() {
@Override
public int compare(int[] o1, int[] o2) {
return o1[0] - o2[0];
}
});
LinkedList<int[]> list = new LinkedList<>();
int left = intervals[0][0];
for (int i = 1; i < intervals.length; i++) {
if (intervals[i][0] > intervals[i - 1][1]){
list.add(new int[]{left, intervals[i - 1][1]});
left = intervals[i][0];
}
else{
intervals[i][1] = Math.max(intervals[i][1], intervals[i - 1][1]);
}
}
list.add(new int[]{left, intervals[intervals.length - 1][1]});
return list.toArray(new int[list.size()][]);
}
}
https://leetcode-cn.com/problems/merge-intervals/
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!