zoukankan      html  css  js  c++  java
  • leetcode57:插入区间

    给出一个无重叠的 ,按照区间起始端点排序的区间列表。

    在列表中插入一个新的区间,你需要确保列表中的区间仍然有序且不重叠(如果有必要的话,可以合并区间)。

    示例 1:

    输入: intervals = [[1,3],[6,9]], newInterval = [2,5]
    输出: [[1,5],[6,9]]
    

    示例 2:

    输入: intervals = [[1,2],[3,5],[6,7],[8,10],[12,16]], newInterval = [4,8]
    输出: [[1,2],[3,10],[12,16]]
    解释: 这是因为新的区间 [4,8][3,5],[6,7],[8,10] 重叠。
    解题思想:
    1.插入新的区间
    2.按照每个区间的起始点排序
    3.合并重叠区间
    代码如下:
    # Definition for an interval.
    # class Interval:
    #     def __init__(self, s=0, e=0):
    #         self.start = s
    #         self.end = e
    
    class Solution:
        def insert(self, intervals, newInterval):
            """
            :type intervals: List[Interval]
            :type newInterval: Interval
            :rtype: List[Interval]
            """
            intervals.append(newInterval)
            l = len(intervals)
            res = []
            intervals = sorted(intervals, key = lambda intervals:intervals.start)
            low = intervals[0].start
            high = intervals[0].end
            for i in range(1, l):
                if intervals[i].start <= high:
                    high = max(high, intervals[i].end)
                else:
                    res.append([low, high])
                    low = intervals[i].start
                    high = intervals[i].end
            res.append([low, high])
            return res
  • 相关阅读:
    数据处理
    Linux常用命令
    三大特征--多态
    封装设计思想--继承
    容器:列表、元组、字典
    封装
    python面向对象,类和对象
    python参数
    js中if条件语句以及switch条件语句的使用
    js中class类的基本理解及相关知识(一)
  • 原文地址:https://www.cnblogs.com/tsdblogs/p/9963171.html
Copyright © 2011-2022 走看看