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
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 背景 一年多以前我在知乎上答了有關(guān)LeetCode的問題, 分享了一些自己做題目的經(jīng)驗。 張土汪:刷leetcod...
    土汪閱讀 12,935評論 0 33
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法,內(nèi)部類的語法,繼承相關(guān)的語法,異常的語法,線程的語...
    子非魚_t_閱讀 34,853評論 18 399
  • 1. Two Sum 用hash可以得到O(n)時間的解法,用python中的enumerate函數(shù),可以獲得元素...
    Morphiaaa閱讀 560評論 0 0
  • ¥開啟¥ 【iAPP實現(xiàn)進入界面執(zhí)行逐一顯】 〖2017-08-25 15:22:14〗 《//首先開一個線程,因...
    小菜c閱讀 7,390評論 0 17
  • (一) 上午收到每天一起朗讀英語的小伙伴的一條信息,她說:你把今天朗讀《Principles》的內(nèi)容以最慢的速度,...
    來是春初閱讀 1,367評論 1 19

友情鏈接更多精彩內(nèi)容