合并区间 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 @   今夜无风  阅读(750)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
点击右上角即可分享
微信分享提示