以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i] = [starti, endi] 。请你合并所有重叠的区间,并返回一个不重叠的区间数组,该数组需恰好覆盖输入中的所有区间。
示例 1:
输入:intervals = [[1,3],[2,6],[8,10],[15,18]]
输出:[[1,6],[8,10],[15,18]]
解释:区间 [1,3] 和 [2,6] 重叠, 将它们合并为 [1,6].
示例 2:
输入:intervals = [[1,4],[4,5]]
输出:[[1,5]]
解释:区间 [1,4] 和 [4,5] 可被视为重叠区间。
#合并区间
def sortIntervals(intervals): #编写函数 插入排序
for i in range(1,len(intervals)):
for j in range(i):
if intervals[i][0]<intervals[j][0]:
tmp=intervals[i]
del intervals[i]
intervals.insert(j,tmp)
return intervals
def merge(intervals): #编写函数,合并区间
sortIntervals(intervals) #第一步是sort,也就是给intervals排序
for i in range(1,len(intervals)): #第二步是合并,并用【0,0】占位
if intervals[i][0] <= intervals[i-1][1]:
intervals[i-1][1]=intervals[i][1]
intervals[i]=[0,0]
while True: #第三步 删除【0,0】
if [0,0] in intervals:
intervals.remove([0,0])
else:
break
return intervals
print(merge([[1,3],[8,10],[2,6],[15,18]]))
print(merge([[1,4],[4,5]]))
print(merge([[1,4],[4,5],[6,12],[11,15]]))
插入排序
【0,0】占位
remove方法