您的位置:首页 > 其它

Merge Intervals(区间合并)

2018-02-27 11:40 447 查看


原题

  Given a collection of intervals, merge all overlapping intervals. 

  For example, 

  Given 
[1,3],[2,6],[8,10],[15,18]


  return 
[1,6],[8,10],[15,18]



题目大意

  给定一个区间集合,合并有重叠的区间。 


解题思路

  先对区间进行排序,按开始点进行排序,再一个一个进行合并。 


代码实现

算法实现类
import java.util.*;

public class Solution {

public List<Interval> merge(List<Interval> intervals) {
List<Interval> result = new LinkedList<>();

if (intervals == null || intervals.size() < 1) {
return result;
}

// 先对区间进行排序,使用一个匿名内部类
Collections.sort(intervals, new Comparator<Interval>() {
@Override
public int compare(Interval o1, Interval o2) {
return o1.start - o2.start;
}
});

// 排序后,后一个元素(记为next)的start一定是不小于前一个(记为prev)start的,
// 对于新添加的区间,如果next.start大于prev.end就说明这两个区间是分开的,要添
// 加一个新的区间,否则说明next.start在[prev.start, prev.end]内,则只要看
// next.end是否是大于prev.end,如果大于就要合并区间(扩大)
Interval prev = null;
for (Interval item : intervals) {

if (prev == null || prev.end < item.start) {
result.add(item);
prev = item;
} else if (prev.end < item.end) {
prev.end = item.end;
}
}

return result;
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37


评测结果

  点击图片,鼠标不释放,拖动一段位置,释放后在新的窗口中查看完整图片。




特别说明


欢迎转载,转载请注明出处【http://blog.csdn.net/derrantcm/article/details/47120501

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: