6.25 - hard - 14

57. Insert Interval

这道题基本上也就是loop一遍,然后对于每一个interval 分三种情况,在start 左边,在end 右边,和当前的start, end 相交。前两种情况直接加入res,最后一种情况扩展start和end

# Definition for an interval.
# class Interval(object):
#     def __init__(self, s=0, e=0):
#         self.start = s
#         self.end = e

class Solution(object):
    def insert(self, intervals, newInterval):
        """
        :type intervals: List[Interval]
        :type newInterval: Interval
        :rtype: List[Interval]
        """
        if not intervals:
            return [newInterval]
        res = []
        start = newInterval.start
        end = newInterval.end
        
        if end < intervals[0].start:
            return [newInterval] + intervals
        if start > intervals[-1].end:
            return intervals + [newInterval]
        
        i = 0
        found = False
        while i < len(intervals):
            if intervals[i].end < start:
                res.append(intervals[i])
            elif intervals[i].start > end:
                if not found:
                    res.append([start, end])
                    found = True
                res.append(intervals[i])
            else:
                start = min(start, intervals[i].start)
                end = max(end, intervals[i].end)
            
            i += 1
        
        if not found:
            res.append([start, end])
        return res
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,766评论 0 33
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,740评论 18 399
  • 1. Two Sum 用hash可以得到O(n)时间的解法,用python中的enumerate函数,可以获得元素...
    Morphiaaa阅读 445评论 0 0
  • ¥开启¥ 【iAPP实现进入界面执行逐一显】 〖2017-08-25 15:22:14〗 《//首先开一个线程,因...
    小菜c阅读 6,497评论 0 17
  • (一) 上午收到每天一起朗读英语的小伙伴的一条信息,她说:你把今天朗读《Principles》的内容以最慢的速度,...
    来是春初阅读 1,255评论 1 19