欢乐力扣:合并区间

文章目录


1、题目描述

合并区间

以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i] = [starti, endi] 。请你合并所有重叠的区间,并返回 一个不重叠的区间数组,该数组需恰好覆盖输入中的所有区间 。

2、思路

这里我参考题解。先将intervals按照左端点进行升序排序,固定住左边,然后遍历不断更新右边的区间即可。

代码

python 复制代码
class Solution:
    def merge(self, intervals: List[List[int]]) -> List[List[int]]:
        # step1: 将intervals里面的每个子list按照第一个元素进行升序排序
        intervals.sort(key=lambda x:x[0])
        # step2: 压入第一个区间
        ans = [intervals[0]]    
        for curlist in intervals[1:]:
            # case1: 若curlist的左端点在当前最后一个节点的中间
            # 则update右侧的较大值
            if curlist[0] >= ans[-1][0] and curlist[0] <= ans[-1][1]:
                ans[-1][1] = max(curlist[1], ans[-1][1])
            # case2: 若没有重合,则直接压入最终结果即可。 
            else:
                ans.append(curlist)
        return ans 
相关推荐
Jasmine_llq16 小时前
《P3157 [CQOI2011] 动态逆序对》
算法·cdq 分治·动态问题静态化+双向偏序统计·树状数组(高效统计元素大小关系·排序算法(预处理偏序和时间戳)·前缀和(合并单个贡献为总逆序对·动态问题静态化
爱吃rabbit的mq17 小时前
第09章:随机森林:集成学习的威力
算法·随机森林·集成学习
(❁´◡`❁)Jimmy(❁´◡`❁)18 小时前
Exgcd 学习笔记
笔记·学习·算法
YYuCChi18 小时前
代码随想录算法训练营第三十七天 | 52.携带研究材料(卡码网)、518.零钱兑换||、377.组合总和IV、57.爬楼梯(卡码网)
算法·动态规划
不能隔夜的咖喱18 小时前
牛客网刷题(2)
java·开发语言·算法
VT.馒头18 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript
进击的小头19 小时前
实战案例:51单片机低功耗场景下的简易滤波实现
c语言·单片机·算法·51单片机
咖丨喱20 小时前
IP校验和算法解析与实现
网络·tcp/ip·算法
罗湖老棍子20 小时前
括号配对(信息学奥赛一本通- P1572)
算法·动态规划·区间dp·字符串匹配·区间动态规划
fengfuyao98521 小时前
基于MATLAB的表面织构油润滑轴承故障频率提取(改进VMD算法)
人工智能·算法·matlab