本题的核心在于区间合并,首先要对区间进行排序,然后通过遍历并合并相邻区间的方式来消除重叠的部分。
具体步骤如下:
start 进行升序排序,如果 start 相同,则按照 end 排序(默认即可)。merged 列表存储合并后的区间。以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i]=[starti,endi] 。请你合并所有重叠的区间,并输出一个不重叠的区间数组,该数组需恰好覆盖输入中的所有区间 。
第一行为一个整数 n ,代表数组 intervals的长度。 接下来的n行,每行有两个整数starti,endi,代表第i个区间。
如题,每行输出一个区间,区间的数字以空额分隔。每个区间以starti升序输出。
输入
4
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] 可被视为重叠区间。