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
  • 相关阅读:
    字符串算法总结
    [HAOI2007]反素数
    Poj2689 Prime Distance
    [APIO2010]特别行动队
    [国家集训队]middle
    Typecho博客迁移实战
    Typora + 七牛云图床 简易配置
    教你用快捷键 以管理员身份运行cmd
    Typecho博客插入B站视频
    七牛云图床快捷上传方法
  • 原文地址:https://www.cnblogs.com/tsdblogs/p/9963171.html
Copyright © 2011-2022 走看看