合并区间 python

# 以数组 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].

方法:快慢指针

def intervals(nums):
    if not nums:
        return []
    # 先对其中元素排序
    nums.sort()
    # 定义快慢指针
    l, r = 0, 1
    while r < len(nums):
        x1, y1 = nums[l][0], nums[l][1]
        x2, y2 = nums[r][0], nums[r][1]
        # 如果快指针的首元素大于慢指针的第二元素,什么也不做进行后移
        if x2>y1:
            l += 1
            r += 1
        # 否则数组合并
        else:
            nums[l] = [x1, max(y1, y2)]
            nums.pop(r)
    return nums

 

posted @ 2021-07-07 11:14  今夜无风  阅读(713)  评论(0编辑  收藏  举报