日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

算法:插入区间

發(fā)布時(shí)間:2025/6/15 编程问答 15 豆豆
生活随笔 收集整理的這篇文章主要介紹了 算法:插入区间 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

?給出一個(gè)無(wú)重疊的 ,按照區(qū)間起始端點(diǎn)排序的區(qū)間列表。

在列表中插入一個(gè)新的區(qū)間,你需要確保列表中的區(qū)間仍然有序且不重疊(如果有必要的話(huà),可以合并區(qū)間)。

示例 1:

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

//插入?yún)^(qū)間func insert(intervals [][]int, newInterval []int) (ans [][]int) {//取出新區(qū)間左端點(diǎn)和右端點(diǎn)left, right := newInterval[0], newInterval[1]merged := falsefor _, interval := range intervals {if interval[0] > right {// 在插入?yún)^(qū)間的右側(cè)且無(wú)交集if !merged {//left和right是之前合并的區(qū)間ans = append(ans, []int{left, right})merged = true}//append合并當(dāng)前符合條件的數(shù)組ans = append(ans, interval)} else if interval[1] < left {// 在插入?yún)^(qū)間的左側(cè)且無(wú)交集ans = append(ans, interval)} else {// 與插入?yún)^(qū)間有交集,計(jì)算它們的并集left = min(left, interval[0])right = max(right, interval[1])}}//最后合并if !merged {ans = append(ans, []int{left, right})}return }func min(a, b int) int {if a < b {return a}return b }func max(a, b int) int {if a > b {return a}return b }

鏈接:https://leetcode-cn.com/problems/insert-interval/solution/cha-ru-qu-jian-by-leetcode-solution/

總結(jié)

以上是生活随笔為你收集整理的算法:插入区间的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。