题目地址:
题目描述:给出一个区间的集合,请合并所有重叠的区间。示例 1:
输入: [[1,3],[2,6],[8,10],[15,18]]
输出: [[1,6],[8,10],[15,18]]解释: 区间 [1,3] 和 [2,6] 重叠, 将它们合并为 [1,6].示例 2:输入: [[1,4],[4,5]]
输出: [[1,5]]解释: 区间 [1,4] 和 [4,5] 可被视为重叠区间。解答:
按照区间起始节点排序。然后合并即可,这题难的是怎么写出完美的合并代码。判断逻辑是如果ans列表为空或者ans列表最后一个区间和当前区间不相交就加入当前区间。否则把ans列表最后一个区间和当前区间合并。java ac代码:
/** * Definition for an interval. * public class Interval { * int start; * int end; * Interval() { start = 0; end = 0; } * Interval(int s, int e) { start = s; end = e; } * } */class Solution { public Listmerge(List intervals) { Collections.sort(intervals, new Comparator () { @Override public int compare(Interval o1, Interval o2) { if(o1.start != o2.start) return o1.start-o2.start; return o1.end-o2.end; } }); List ans = new ArrayList(intervals.size()); for(int i = 0;i < intervals.size();i++) if(ans.size() == 0||ans.get(ans.size()-1).end < intervals.get(i).start) ans.add(intervals.get(i)); else ans.get(ans.size()-1).end =Math.max(intervals.get(i).end,ans.get(ans.size()-1).end ); return ans; }}