LeetCode Hot100 之 17 合并区间

题目

分析

先将intervals按起始点升序排列,然后遍历,如果当前数组的起点小于前面数组的结束则需要合并,否则就直接加入返回数组。

代码

cpp 复制代码
class Solution {
public:
    vector<vector<int>> merge(vector<vector<int>>& intervals) {
        std::sort(intervals.begin(), intervals.end());
        std::vector<std::vector<int>> res;
        if (!intervals.empty()) {
            res.push_back(intervals[0]);
        }

        for (int i = 1; i < intervals.size(); ++i) {
            // 获取结果数组最后一个区间的引用
            std::vector<int>& last_merged = res.back();
            
            // 如果当前区间的开始小于等于上一个合并区间的结束,则合并
            if (intervals[i][0] <= last_merged[1]) {
                 // 合并:更新上一个区间的结束点为两者中较大的
                last_merged[1] = std::max(last_merged[1], intervals[i][1]);
            } else {
                // 否则,无重叠,直接添加新区间
                res.push_back(intervals[i]);
            }
        }
        return res;
    }
};

结果

相关推荐
你怎么知道我是队长2 小时前
C语言---排序算法8---递归快速排序法
c语言·算法·排序算法
007张三丰2 小时前
软件测试专栏(5/20):自动化测试入门指南:从零开始构建你的第一个测试框架
自动化测试·python·算法·压力测试·测试框架
Zachery Pole2 小时前
根据高等代数与数分三计算线性回归中的w
算法·回归·线性回归
得一录2 小时前
星图·全参数调试qwen3.1-B
深度学习·算法·aigc
yyjtx2 小时前
DHU上机打卡D22
算法
plus4s2 小时前
2月14日(76-78题)
c++·算法·图论
pzx_0012 小时前
【论文阅读】Attention Is All You Need
论文阅读·算法
-To be number.wan2 小时前
算法学习日记 |贪心算法
c++·学习·算法·贪心算法
清钟沁桐3 小时前
算法实现
算法