LeetCode每日一题:56. 合并区间(2023.8.27 C++)

目录

[56. 合并区间](#56. 合并区间)

题目描述:

实现代码与解析:

[排序 + 贪心](#排序 + 贪心)

原理思路:


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

实现代码与解析:

排序 + 贪心

cpp 复制代码
class Solution {
public:
    vector<vector<int>> merge(vector<vector<int>>& intervals) {
        // 从小到大,按左端排序
        sort(intervals.begin(), intervals.end(), [&](const auto &a, auto &b){
            return a[0] < b[0];
        });

        vector<vector<int>> res;
        res.push_back(intervals[0]);

        for (int i = 0; i < intervals.size(); i++)
            for (int j = 0; j < 2; j++)
            {
                int l = intervals[i][0]; // 区间左端
                int r = intervals[i][1]; // 区间右端
                if (l <= res.back()[1] && r > res.back()[1])  res.back()[1] = r; // 有重叠, 但不包含
                else if (l <= res.back()[1] && r <= res.back()[1]); // 有重叠,但是包含
                else res.push_back({l, r}); // 无重叠
            }
        
        return res;
    }
};

原理思路:

先将区间按左端点排序,然后遍历,若后区间的左端点小于等于前区间的右端点,就将两区间合并,谁的右端点大就用谁的,若无重合区间,直接将区间加入结果中。

相关推荐
tigershang几秒前
卡尔曼滤波:不确定世界中的最优估计
人工智能·算法·机器学习
凡人叶枫1 分钟前
Effective C++ 条款02:宁可以编译器替换预处理器
java·linux·c语言·开发语言·c++
一个儒雅随和的男子14 分钟前
限流算法详细剖析
java·服务器·算法
AC赳赳老秦20 分钟前
用 OpenClaw 制定技术学习计划:根据目标岗位自动生成学习路线、推荐学习资源
开发语言·c++·人工智能·python·mysql·php·openclaw
ShineWinsu1 小时前
对于Linux:内核是如何组织管理IPC资源的解析
linux·服务器·c++·面试·笔试·线程·ipc
少司府1 小时前
C++进阶:红黑树
开发语言·数据结构·c++·b树·二叉树·红黑树
工业胶粘剂技术1 小时前
单组分高温环氧结构胶 K-EP280 完整技术参数与工程选型分析
算法·制造
汉克老师1 小时前
GESP6级C++考试语法知识(五十五、动态规划----背包问题(八、混合背包)
c++·动态规划·dp·背包问题·gesp六级·混合背包问题
特种加菲猫1 小时前
哈希表的实现
开发语言·c++
玖釉-2 小时前
nvpro_core2 详解:NVIDIA Vulkan / OpenGL 图形样例背后的现代 C++ 基础库
c++·windows·图形渲染