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

相关推荐
凌波粒10 分钟前
LeetCode--108.将有序数组转换为二叉搜索树(二叉树)
算法·leetcode·职场和发展
liulilittle10 分钟前
KCC:在 BBR 思路上的一次探索
网络·tcp/ip·算法·bbr·通信·拥塞控制·kcc
浦信仿真大讲堂32 分钟前
达索系统SIMULIA Abaqus 2026接触和约束的增强新功能介绍
人工智能·python·算法·仿真软件·达索软件
点云侠42 分钟前
PCL 生成三棱锥点云
c++·算法·最小二乘法
兰令水1 小时前
leecodecode【面试150】【2026.6.13打卡-java版本】
java·算法·leetcode
临沂堇1 小时前
刷题日志 | Leetcode Hot 100 哈希
算法·leetcode·哈希算法
玉小格1 小时前
一次关于Python的总结
算法
伊甸31 小时前
从企业级项目学敏感词过滤:DFA算法与双层缓存实战
java·算法·缓存
bIo7lyA8v2 小时前
算法中的随机化思想及其复杂度收益评估的技术8
算法
数据法师2 小时前
视频文件重复检测工具:基于哈希与视频指纹的三级筛选机制
算法·音视频·哈希算法