57. 插入区间(C++题解)

57. 插入区间

插入区间

给你一个无重叠的 ,按照区间起始端点排序的区间列表。

在列表中插入一个新的区间,你需要确保列表中的区间仍然有序且不重叠(如果有必要的话,可以合并区间)。

示例 1:

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

输出:[[1,5],[6,9]]

示例 2:

输入:intervals = [[1,2],[3,5],[6,7],[8,10],[12,16]], newInterval = [4,8]

输出:[[1,2],[3,10],[12,16]]

解释:这是因为新的区间 [4,8] 与 [3,5],[6,7],[8,10] 重叠。

示例 3:

输入:intervals = [], newInterval = [5,7]

输出:[[5,7]]

示例 4:

输入:intervals = [[1,5]], newInterval = [2,3]

输出:[[1,5]]

示例 5:

输入:intervals = [[1,5]], newInterval = [2,7]

输出:[[1,7]]

提示:

0 <= intervals.length <= 104

intervals[i].length = 2

0 <= intervals[i][0] <= intervals[i][1] <= 105

intervals 根据 intervals[i][0] 按 升序 排列

newInterval.length = 2

0 <= newInterval[0] <= newInterval[1] <= 105

思路

最开始的思路就是,先把新的区间按照起点的顺序插入到旧区间内,之后对所有区间进行判断,来将可以合并的区间合并起来。但是如果直接这样做的话,因为插入的时候需要将所有元素后移一位,而对于区间合并,每次合并后都需要删除一个元素,导致每次需要将所有元素前移一位,这样的在后面测试案例较大的时候是没法通过的。因此需要别的思路来解决这几个问题。 除此之外,还需要知道,有两个区间(a,b),(c,d),当发现c<b的时候,说明两个区间需要合并。并且合并后的区间是(a,max(b,d))。

解题方法

创建一个ans来保存最后的区间列表,第一步,将新的区间插入到旧区间内,这里采用,遍历旧区间intervals,通过判断newInterval的起点大小,把小于newInterval起点的区间放进ans中,当发现不满足的时候,就是该放入newInterval的位置了,这个时候就可以把newInterval加入ans中。这样就做到了将newInterval插入到旧区间内。 第二步,进行判断新插入的区间newInterval是否需要合并,与ans中最后一个区间进行判断(此时newInterval还没有插入ans中),如果需要合并那么直接合并就行了,也就不需要newInterval插入了。 第三步,在把新的区间newInterval放入(包括合并)后,就需要把intervals剩下的区间加入ans中了,不过在加入的时候需要进行判断,如果需要合并,那么直接合并。如果不需要合并,只需要加入剩下的区间了。 第四步,在第三步之前,考虑了一个特殊情况,也就是新区间是是放入最后一个位置,这个时候需要单独把newInterval放入ans后,并且判断是否需要合并。

复杂度

时间复杂度:

O(n)

空间复杂度:

O(n)

Code

cpp 复制代码
class Solution {
public:
    vector<vector<int>> insert(vector<vector<int>>& intervals, vector<int>& newInterval) {
        vector<vector<int>> ans;
        if(intervals.size()==0){
            intervals.push_back(newInterval);
            return intervals;
        }
        int i=0,k=0;
        //找到新区间应该放置在旧区间的位置
        for(;i<intervals.size();++i){
            if(newInterval[0]<=intervals[i][0]){
                if(i>0&&newInterval[0]<=intervals[i-1][1]){
                    ans[i-1][1]=max(ans[i-1][1],newInterval[1]);
                    k=i-1;
                }
                else{
                    k=i;
                    ans.push_back(newInterval);
                }
                break;
            }
            ans.push_back(intervals[i]);
        }
        //如果新的区间放在最后一个位置
        if(i==intervals.size()){
            if(newInterval[0]<=intervals[i-1][1]){
                ans[i-1][1]=max(ans[i-1][1],newInterval[1]);
            }
            else{
                ans.push_back(newInterval);
            }
        }
        //新的区间放在了旧区间中
        for(;i<intervals.size();++i){
            if(ans[k][1]>=intervals[i][0]){
                ans[k][1]=max(ans[k][1],intervals[i][1]);
            }
            else{
                ans.push_back(intervals[i]);
            }
        }
        return ans;
    }
};
相关推荐
Boilermaker1992几秒前
[算法基础] FooldFill(DFS、BFS)
算法·深度优先·宽度优先
Aevget3 分钟前
MFC扩展库BCGControlBar Pro v37.1亮点:Ribbon Bar组件全新升级
c++·ribbon·mfc·bcg·界面控件·ui开发
superman超哥3 分钟前
Rust 所有权转移在函数调用中的表现:编译期保证的零成本抽象
开发语言·后端·rust·函数调用·零成本抽象·rust所有权转移
xiaowu0803 分钟前
C# 把dll分别放在指定的文件夹的方法
开发语言·c#
leiming67 分钟前
c++ find 算法
算法
CoovallyAIHub9 分钟前
YOLOv12之后,AI在火场如何进化?2025最后一篇YOLO论文揭示:要在浓烟中看见关键,仅靠注意力还不够
深度学习·算法·计算机视觉
梭七y9 分钟前
【力扣hot100题】(121)反转链表
算法·leetcode·链表
cchjyq10 分钟前
嵌入式按键调参:简洁接口轻松调参(ADC FLASH 按键 屏幕参数显示)
c语言·c++·单片机·mcu·开源·开源软件
程序炼丹师10 分钟前
std::runtime_error是否会终止程序
c++
mg66811 分钟前
0基础开发学习python工具_____用 Python + Pygame 打造绚丽烟花秀 轻松上手体验
开发语言·python·学习·pygame