Leetcode 57 Insert Interval

扯閑篇

為啥寫這個(gè)題目?因?yàn)檫@個(gè)題目是merge interval的一個(gè)小變種。知道了merge怎么做 然后想一想這個(gè)怎么做 就會(huì)做了。

題目

Given a set of non-overlapping intervals, insert a new interval into the intervals (merge if necessary).

You may assume that the intervals were initially sorted according to their start times.

Example 1:

Given intervals[1,3],[6,9], insert and merge[2,5]in as[1,5],[6,9].

Example 2:

Given[1,2],[3,5],[6,7],[8,10],[12,16], insert and merge[4,9]in as[1,2],[3,10],[12,16].

This is because the new interval[4,9]overlaps with[3,5],[6,7],[8,10].

分析

題目說的很清楚了,首先數(shù)組上來默認(rèn)是排序的,然后告訴我們了,不加入新的數(shù)組 數(shù)組之間本來是沒有重合的。

啥意思?。?/p>

1. 不用排序

2. 數(shù)組本來不需要?dú)w并,加入了一個(gè)新數(shù)組才需要?dú)w并

然后呢?

所以我們之前如果做過歸并 那就知道了,這道題目的點(diǎn)在兩個(gè)

1. 找到開始?xì)w并的點(diǎn)

2. 歸并

好了 歸并的話就按照歸并那道題目的要求來做唄。那要如何找到歸并點(diǎn)呢?歸并點(diǎn)就是interval[i].end > newInterval.start的第一個(gè)點(diǎn)。

那merge的結(jié)束點(diǎn)呢? ?結(jié)束點(diǎn)就是interval[i].start >newInterval.end 的第一個(gè)點(diǎn)。 ?這就可以做了

代碼自己點(diǎn)開看哈~~~~

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

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

  • 背景 一年多以前我在知乎上答了有關(guān)LeetCode的問題, 分享了一些自己做題目的經(jīng)驗(yàn)。 張土汪:刷leetcod...
    土汪閱讀 12,925評(píng)論 0 33
  • 題目 Given a set of non-overlapping intervals, insert a new...
    persistent100閱讀 151評(píng)論 0 0
  • 原題 給出一個(gè)無重疊的按照區(qū)間起始端點(diǎn)排序的區(qū)間列表。在列表中插入一個(gè)新的區(qū)間,你要確保列表中的區(qū)間仍然有序且不重...
    Jason_Yuan閱讀 597評(píng)論 0 0
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,606評(píng)論 19 139
  • 拍完畢業(yè)照,我們彼此擁抱,喝了最后一瓶酒,收拾了床,還回了鑰匙,郵寄行李,拿著自己的入職文件,走入了一片再也沒有遮...
    錦鯉熊閱讀 594評(píng)論 2 0

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