給出一個區間的集合,請合并所有重疊的區間。
示例 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] 可被視為重疊區間。
def hebing(num_li:list):
num_li=sorted(num_li,key=lambda x:x[0])
while len(num_li)>1:
for i in range(len(num_li)-1):
start= num_li[i]
end= num_li[i+1]
if start[1]>=end[0] and start[0]<end[1]:
num_li.insert(i,[start[0],end[1]])
num_li.remove(start)
num_li.remove(end)
break
else:
break
return num_li
li1 = [[1,3],[2,6],[9,100],[37,50]]
res = hebing(li1)
print(res)