public static ArrayList<Interval> merge(ArrayList<Interval> intervals) {
intervals.sort(new Comparator<Interval>() {
@Override
public int compare(Interval o1, Interval o2) {
return o1.start - o2.start;
}
});
int j = 1;
int i = 0;
while (j < intervals.size()) {
Interval before = intervals.get(i);
Interval after = intervals.get(j);
if (before.end >= after.start) {
Interval tmp = new Interval(before.start, Math.max(before.end, after.end));
intervals.remove(i); // 重点删除后,位置会往后移
intervals.remove(i);
intervals.add(i, tmp); // 重点add, 不是set
} else {
i++;
j++;
}
}
return intervals;
}