Leetcode每日一题:56. 合并区间

原题

以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i] = [starti, endi] 。请你合并所有重叠的区间,并返回 一个不重叠的区间数组,该数组需恰好覆盖输入中的所有区间

示例 1:

复制代码
输入:intervals = [[1,3],[2,6],[8,10],[15,18]]
输出:[[1,6],[8,10],[15,18]]
解释:区间 [1,3] 和 [2,6] 重叠, 将它们合并为 [1,6].

示例 2:

复制代码
输入:intervals = [[1,4],[4,5]]
输出:[[1,5]]
解释:区间 [1,4] 和 [4,5] 可被视为重叠区间。

提示:

  • 1 <= intervals.length <= 104
  • intervals[i].length == 2
  • 0 <= starti <= endi <= 104

解题思路

什么情况下区间需要合并?当然是一个区间的开始位置,位于另一个区间上的情况才需要合并。我们假设区间为Range,包含left和and两个值。为了方便处理,我们需要让Range2.left在Range1的left和right之间,因此这里需要根据left进行排序。在left有序的情况下,合并后的区间为Range1.left,newRight,其中newRight = max(Range1.right,Range2.right)。我们可以将排序后的区间依次加入结果数组,如果当前区间和结果数组的最后一个区间不重叠(也就是Range2.left>Range1.right),就加入。否则就将合并后的区间替换结果数组的最后一个区间(严格讲只要替换最后一个区间的Right为newRight就行)。完整实现如下:

cpp 复制代码
lass Solution {
public:
    vector<vector<int>> merge(vector<vector<int>>& intervals) {
        if (intervals.size() == 0) {
            return {};
        }
        sort(intervals.begin(), intervals.end());
        vector<vector<int>> merged;
        for(int i = 0; i < intervals.size(); i++){
            int L = intervals[i][0], R = intervals[i][1];
            if (!merged.size() || merged.back()[1] < L) {
                merged.push_back({L, R});
            }
            else {
                merged.back()[1] = max(merged.back()[1], R);
            }
        }
        return merged;
    }
};

最后

合并区间是一个非常有用的算法,今年和某数据引擎企业合作,为某电视台的视频APP实施埋点方案。其中有一条就是要统计某个视频的观看时长。这个时长不是我们平时意义上看了几分钟,而是这个视频内容里有多久被看了,不管是一倍速还是几倍速看的。那么我们需要记录每个操作,播放、暂停、拖动开始和结束、切换速率等,然后再将这些事件点转为区间,然后实施区间合并,这才最终得出了我们想要的结果。由此可见,区间合并在我们实际开发中还是很有用处的。

相关推荐
满怀冰雪6 小时前
第13篇-栈算法入门-括号匹配-表达式与单调栈基础
java·算法
TCW11217 小时前
AI底层系列:用C++实现线性代数的公式推导与算法设计-基础篇-5.矩阵方程
人工智能·线性代数·算法
叫我:松哥7 小时前
基于机器学习和flask的体育健身风险智能分析系统,系统集成DeepSeek、聚类算法、分类算法等,准确率达90%
人工智能·python·神经网络·算法·机器学习·flask·聚类
wabs6667 小时前
关于动态规划【0-1背包思想在实际问题中是怎么转化的?】
算法·动态规划
阿文的代码库7 小时前
欧拉回路与欧拉路径的算法流程演示
算法
汤姆yu7 小时前
云知声 U2 原生智能体大模型深度解析
大数据·人工智能·算法·ai·大模型·多模态·智能体
syt_biancheng7 小时前
贪心算法(1)---简介
算法·贪心算法
小白小宋7 小时前
【PUSCH番外篇】5G NR 相位补偿与频移校正:原理、流程与工程实现
算法·5g·matlab·信息与通信·信号处理
满怀冰雪7 小时前
第15篇-链表基础-反转链表-合并链表与快慢指针
java·算法·链表
2zcode7 小时前
基于MATLAB语音信号变声算法设计与实现
算法·matlab·语音识别·变声算法