博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[Leetcode]合并区间
阅读量:4163 次
发布时间:2019-05-26

本文共 953 字,大约阅读时间需要 3 分钟。

[Leetcode]合并区间

题目描述

给出一个区间的集合,请合并所有重叠的区间。

示例 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] 可被视为重叠区间。
注意:输入类型已于2019年4月15日更改。 请重置默认代码定义以获取新方法签名。

提示:

intervals[i][0] <= intervals[i][1]

解题思路
  • 先对数组进行排序,这样就可以保证 tmp1 与 tmp2 做合并时,tmp1[0] < tmp2[0]
  • 然后,对于 tmp1 与 tmp2 有三种情况:
    • 交叉

      在这里插入图片描述

    • 包含

      在这里插入图片描述

    • 不相交

      在这里插入图片描述

  • 那么,比较 tmp1[1] 与 tmp2[1],可以判断是 相交 还是 包含,进行区间合并;比较 tmp1[1] 与 tmp2[0] 可以判断是否是不相交
实现代码
class Solution:    def merge(self, intervals: List[List[int]]) -> List[List[int]]:        intervals.sort(key=lambda x: x[0])                merged = []        for interval in intervals:            # 如果列表为空,或者当前区间与上一区间不重合,直接添加            if not merged or merged[-1][1] < interval[0]:                merged.append(interval)            else:                # 否则的话,我们就可以与上一区间进行合并                merged[-1][1] = max(merged[-1][1], interval[1])        return merged

转载地址:http://iyoxi.baihongyu.com/

你可能感兴趣的文章
SuperMap iClient3D for WebGL教程-CallbackProperty
查看>>
如何修改leaflet聚合图的层级和样式
查看>>
三维分析之开敞度分析
查看>>
BIM+GIS应用的八大挑战
查看>>
.net实现.aspx页面自动加载.cs程序定义的变量并按照格式输出
查看>>
[Leetcode]最后一个单词的长度
查看>>
merges sort use c++
查看>>
插入排序用递归实现
查看>>
工作流审批平台-审批流程-指定审批部门
查看>>
商务智能-系统概述-数据图形方式
查看>>
软件项目管理系统-项目管理-模块定义-开发内容
查看>>
工作流审批平台-审批功能
查看>>
商务智能-基本方法-特征与角度
查看>>
软件项目管理系统-项目管理-模块定义-开发笔记
查看>>
工作流审批平台-业务申请-申请书一览
查看>>
商务智能-基本方法-数据钻取
查看>>
VS2008非托管c++访问webservice服务
查看>>
C++extern用法
查看>>
vc++生成程序不需要.net运行环境的可以执行exe程序的方法
查看>>
fstream默认不支持中文路径和输出整数带逗号的解决办法
查看>>