力扣57:插入區間

力扣57:插入區間

  • 題目
  • 思路
  • 代碼

題目

給你一個 無重疊的 ,按照區間起始端點排序的區間列表 intervals,其中 intervals[i] = [starti, endi] 表示第 i 個區間的開始和結束,并且 intervals 按照 starti 升序排列。同樣給定一個區間 newInterval = [start, end] 表示另一個區間的開始和結束。

在 intervals 中插入區間 newInterval,使得 intervals 依然按照 starti 升序排列,且區間之間不重疊(如果有必要的話,可以合并區間)。

返回插入之后的 intervals。

注意 你不需要原地修改 intervals。你可以創建一個新數組然后返回它。

思路

這道題和56題合并區間是相同的思路,只不過一個是合并一個是插入。我們還是先思考兩個區間之間存在著什么樣的關系,兩個區間其實只有重疊和不重疊兩種關系,或者是重疊就是一個區間的左邊界大于另外一個區間的左邊界但是小于它的右邊界,而不重疊就是一個區間的左邊界大于另外一個區間的右邊界或者一個區間的右邊界小于另外一個區間的左邊界。理清了這些關系后這道題就好做了。
那么這道題和56題不同的地方在什么呢?在于我們需要插入一個新區間所以我們必須判斷什么時候插入這個新區間,其實就兩種情況一是有比我們還大的區間也就是左邊界都已經大于我們的右邊界了或者是我們直到最后發現新區間還沒有插入也就是說新區間是最后的區間的情況下。所以我們需要定義一個bool類型來判斷新區間是否插入了如果在最后發現它沒插入我們就需要將其插入

代碼

class Solution {
public:vector<vector<int>> insert(vector<vector<int>>& intervals,vector<int>& newInterval) {int L = newInterval[0];int R = newInterval[1];vector<vector<int>> res;bool isInsert = false;for (int i = 0; i < intervals.size(); i++) {// 其實一共就三種情況// 右邊界小于L,直接插入if (intervals[i][1] < L) {res.push_back(intervals[i]);}// 左邊界大于R,先插入[L,R]再插入當前區間else if (intervals[i][0] > R) {if (isInsert == false) {res.push_back({L, R});isInsert = true;}res.push_back(intervals[i]);}// 右邊界大于L,但是小于R或者左邊界小于R但是右邊界大于R,直接更新else {L = min(L, intervals[i][0]);R = max(R, intervals[i][1]);}}// 如果插入區間還沒插入就說明它就是最后一個區間if (isInsert == false) {res.push_back({L, R});}return res;}
};

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/93890.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/93890.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/93890.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

KVM虛擬化技術解析:從企業應用到個人創新的開源力量

1 .KVM&#xff1a;開源虛擬化的核心引擎 KVM&#xff08;Kernel-based Virtual Machine&#xff09;作為Linux內核原生集成的開源虛擬化模塊&#xff0c;徹底改變了現代數據中心的虛擬化格局。它通過將Linux內核轉變為Type-1型虛擬機監控器&#xff08;Hypervisor&#xff09;…

28.Linux :通過源代碼編譯安裝lamp

Linux &#xff1a;通過源代碼編譯安裝lamp 區別特性源代碼編譯安裝yum 安裝安裝方式從源代碼編譯構建預編譯的二進制包自定義程度高度可定制有限定制性能優化可針對特定硬件優化通用優化依賴管理手動解決依賴關系自動解決依賴安裝復雜度復雜&#xff0c;需技術經驗簡單&#x…

應用控制技術

一、 應用特征識別技術1.傳統行為檢測技術1.1 五元組檢測原理1.2 配置思路1.3 效果展示需求背景21.4 傳統行為檢測的缺陷無法識別應用層內容&#xff1a;若應用更換端口&#xff08;如QQ改用隨機端口&#xff09;或偽裝協議&#xff08;如HTTPS加密&#xff09;&#xff0c;傳統…

當MySQL的int不夠用了

關于int的長度很多時候看到int(8)這樣的定義&#xff0c;其實這是工具導出的不專業。int是范圍&#xff0c;不是長度。在開發有了共識&#xff08;知道這個長度不算數&#xff0c;要看范圍&#xff09;以后&#xff0c;上來就是所有的類型都是bigint。int的范圍int的取值范圍是…

讓AI學會“邊做邊想“:ReAct的實戰指南

小智的求職困境有個叫小智的AI助手&#xff0c;它剛從"大語言模型大學"畢業&#xff0c;滿懷信心地去應聘一家咨詢公司的智能助理職位。面試官問&#xff1a;"北京和上海哪個城市人口更多&#xff1f;"小智立刻回答&#xff1a;"根據我的知識&#xf…

vue優化有哪些手段?

vue本身存在的方法 v-if 和v-show 的合理運用,頻繁使用的組件使用v-show,不頻繁的使用v-if,來減少dom的渲染路由懶加載 采用()>import(index.vue)當路由被訪問的時候才回去加載使用keep-alive緩存頁面,減少沒必要的重復渲染同時也可以減少服務器的壓力使用computed緩存數據,…

【圖像算法 - 14】精準識別路面墻體裂縫:基于YOLO12與OpenCV的實例分割智能檢測實戰(附完整代碼)

摘要&#xff1a; 裂縫是結構健康的重要隱患&#xff0c;傳統人工巡檢耗時耗力且易遺漏。本文將帶您利用當前最先進的YOLO12實例分割模型&#xff0c;構建一個高效、準確、更高精度的裂縫檢測系統。我們將從數據準備、模型訓練到結果可視化&#xff0c;手把手實現一個完整的項目…

“讓機器人更智慧 讓具身體更智能”北京世界機器人大會行業洞察

2025年8月8日&#xff0c;世界機器人大會在北京盛大開幕。本屆大會以“讓機器人更智慧 讓具身體更智能”為主題&#xff0c;由中國電子學會、世界機器人合作組織主辦&#xff0c;包括開幕式、閉幕式、論壇等。同期舉辦世界機器人博覽會、世界機器人大賽等活動&#xff0c;打造了…

PHP如何使用JpGraph生成折線圖?

JpGraph是一個功能強大的PHP圖表庫&#xff0c;它通過封裝GD庫函數&#xff0c;為開發者提供了簡單高效的數據可視化解決方案。作為專門用于繪制統計圖的面向對象庫&#xff0c;JpGraph支持創建折線圖、柱狀圖、餅圖等20余種圖表類型&#xff0c;并能自動處理坐標軸、刻度、圖例…

超級云平臺:重構數字生態的“超級連接器“

在數字經濟浪潮席卷全球的今天,企業數字化轉型已從"選擇題"變為"必答題"。然而,傳統云服務模式因技術壁壘高、資源分散、協同效率低等問題,讓許多企業在數字化轉型中陷入"上云易、用云難"的困境。 在此背景下,一種以"全域資源整合+智能…

https如何保證傳遞參數的安全

HTTPS 并非直接“加密參數”&#xff0c;而是通過一整套加密傳輸機制&#xff0c;確保客戶端與服務器之間所有通信內容&#xff08;包括 URL 參數、表單數據、Cookie 等&#xff09;在傳輸過程中不被竊聽、篡改或偽造。其核心安全保障來自以下技術實現&#xff1a; 一、核心加密…

OpenHarmony之打造全場景智聯基座的“分布式星鏈 ”WLAN子系統

1. 技術架構概覽 無線局域網(Wireless Local Area Networks,WLAN),是通過無線電、紅外光信號或者其他技術發送和接收數據的局域網,用戶可以通過WLAN實現結點之間無物理連接的網絡通訊。常用于用戶攜帶可移動終端的辦公、公眾環境中。 WLAN組件子系統為用戶提供WLAN基礎功…

JMeter(入門篇)

一.簡介 JMeter 是 Apache 組織使用 Java 開發的一款測試工具。 1、可以用于對服務器、網絡或對象模擬巨大的負載 2、通過創建帶有斷言的腳本來驗證程序是否能返回期望的結果 二.優缺點 優點&#xff1a; 開源、免費 跨平臺 支持多協議 小巧 功能強大 缺點&#xff…

Lecture 12: Concurrency 5

回顧&#xff1a;并行用餐哲學家讀者/作者問題哲學家進餐問題方案三&#xff1a;最大化并行需要一個更復雜的解決方案來實現最大的并行性 解決方案使用&#xff1a;state[N]&#xff1a;每個哲學家的當前狀態&#xff08;THINKING&#xff0c; HUNGRY&#xff0c; EATING&#…

UniApp 微信小程序之間跳轉指南

概述 在UniApp開發中&#xff0c;經常需要實現從當前小程序跳轉到其他微信小程序的功能。本文檔詳細介紹了如何在UniApp中實現微信小程序之間的跳轉。 核心API uni.navigateToMiniProgram() 這是UniApp提供的用于跳轉到其他微信小程序的核心API。 基本語法 uni.navigateToMiniP…

基于SpringBoot+Vue的養老院管理系統的設計與實現 智能養老系統 養老架構管理 養老小程序

&#x1f525;作者&#xff1a;it畢設實戰小研&#x1f525; &#x1f496;簡介&#xff1a;java、微信小程序、安卓&#xff1b;定制開發&#xff0c;遠程調試 代碼講解&#xff0c;文檔指導&#xff0c;ppt制作&#x1f496; 精彩專欄推薦訂閱&#xff1a;在下方專欄&#x1…

TRAE調教指南:用6A工作流項目規則+5S敏捷個人規則打造高效AI開發流程

TRAE調教指南&#xff1a;用6A工作流項目規則5S敏捷個人規則打造高效AI開發流程 引言&#xff1a;從"AI瞎寫"到"精準交付"的實戰手冊一、什么是Rules&#xff1a;讓AI"聽話"的底層邏輯1. 告別重復指令疲勞2. 實現"千人千面"的個性化適…

【C語言】gets和getchar的區別

在C語言中&#xff0c;gets和getchar是兩個用于輸入的標準函數&#xff0c;它們在功能和用法上有所不同。 功能上&#xff1a; gets函數主要用于讀取一行字符串&#xff0c;直到遇到換行符&#xff08;回車鍵&#xff09;為止。它會自動過濾掉換行符&#xff0c;不會將其讀入到…

【數據結構與算法】數據結構初階:詳解二叉樹(一)

&#x1f525;個人主頁&#xff1a;胡蘿卜3.0 &#x1f3ac;作者簡介&#xff1a;C研發方向學習者 &#x1f4d6;個人專欄&#xff1a; 《C語言》《數據結構》 《C干貨分享》 ??人生格言&#xff1a;不試試怎么知道自己行不行 正片開始之前&#xff0c;我們來了解一下我們即…

工具測試 - marker (Convert PDF to markdown + JSON quickly with high accuracy)

參考鏈接如下&#xff1a;&#xff1a; 參考鏈接&#xff1a;https://github.com/datalab-to/marker?tabreadme-ov-file#llm-services 底層的OCR模型&#xff1a;https://github.com/datalab-to/surya 作用&#xff1a;開源免費&#x1f193;&#xff0c;多 GPU 推理、生成效…