LeetCode 算法:合并区间c++

原题链接🔗合并区间
难度:中等⭐️⭐️

题目

以数组 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

题解

贪心算法

  1. 题解

合并区间问题是一个典型的贪心算法问题,其核心思想是将区间按照开始时间进行排序,然后依次合并重叠的区间。以下是解决这个问题的详细步骤:

  • 排序:首先,将所有区间按照每个区间的开始时间进行升序排序。如果开始时间相同,则可以按照结束时间进行升序排序,但通常这并不影响最终结果。

  • 初始化:创建一个结果数组result,用于存储合并后的区间。将排序后的区间数组的第一个区间添加到result中。

  • 遍历和合并:遍历排序后的区间数组,对于每个区间,执行以下操作:

    • 如果当前区间的开始时间小于或等于result中最后一个区间的结束时间,说明这两个区间有重叠,需要合并。将result中最后一个区间的结束时间更新为当前区间的结束时间和result中最后一个区间的结束时间中的较大者。
    • 如果当前区间的开始时间大于result中最后一个区间的结束时间,说明这两个区间没有重叠,直接将当前区间添加到result中。
  • 返回结果:遍历完成后,result中存储的就是所有合并后的区间,返回这个数组。

  1. 复杂度:时间复杂度O(nlogn),空间复杂度O(n)
  2. 过程
  • 定义了Solution类,其中包含了merge函数,用于合并区间。
    • 先调用sort函数对所以区间排序;
    • for循环遍历每个区间,比较区间进行合并;
  • 在main函数中,创建了Solution类的实例,提供了测试用例;测试用例都打印出合并后的区间。
  1. c++ demo
cpp 复制代码
#include <iostream>
#include <vector>
#include <algorithm>

class Solution {
public:
    std::vector<std::vector<int>> merge(std::vector<std::vector<int>>& intervals) {
        if (intervals.empty()) return {};

        // 按照区间的开始位置进行排序
        std::sort(intervals.begin(), intervals.end());

        std::vector<std::vector<int>> merged;
        merged.push_back(intervals[0]);

        for (const auto& interval : intervals) {
            // 获取合并后的最后一个区间
            auto& last = merged.back();
            if (interval[0] <= last[1]) {
                // 如果有重叠,合并区间
                last[1] = std::max(last[1], interval[1]);
            }
            else {
                // 否则,添加新的区间
                merged.push_back(interval);
            }
        }

        return merged;
    }
};

int main() {
    Solution solution;
    // 示例输入
    std::vector<std::vector<int>> intervals = {{1, 3}, {2, 6}, {8, 10},{15, 18} };

    // 调用函数并打印结果
    std::vector<std::vector<int>> mergedIntervals = solution.merge(intervals);
    for (const auto& interval : mergedIntervals) {
        std::cout << "[" << interval[0] << ", " << interval[1] << "]" << " ";// << std::endl;
    }

    return 0;
}
  • 输出结果:

1, 6\] \[8, 10\] \[15, 18

相关推荐
luckys.one6 小时前
第9篇:Freqtrade量化交易之config.json 基础入门与初始化
javascript·数据库·python·mysql·算法·json·区块链
~|Bernard|8 小时前
在 PyCharm 里怎么“点鼠标”完成指令同样的运行操作
算法·conda
战术摸鱼大师8 小时前
电机控制(四)-级联PID控制器与参数整定(MATLAB&Simulink)
算法·matlab·运动控制·电机控制
Christo38 小时前
TFS-2018《On the convergence of the sparse possibilistic c-means algorithm》
人工智能·算法·机器学习·数据挖掘
好家伙VCC9 小时前
数学建模模型 全网最全 数学建模常见算法汇总 含代码分析讲解
大数据·嵌入式硬件·算法·数学建模
利刃大大10 小时前
【高并发内存池】五、页缓存的设计
c++·缓存·项目·内存池
C语言小火车10 小时前
【C++八股文】基础知识篇
c++·tcp/ip·const·智能指针·多线程同步·static关键字·c++内存模型
liulilittle11 小时前
IP校验和算法:从网络协议到SIMD深度优化
网络·c++·网络协议·tcp/ip·算法·ip·通信
眠りたいです11 小时前
基于脚手架微服务的视频点播系统-播放控制部分
c++·qt·ui·微服务·云原生·架构·播放器
Want59511 小时前
C/C++圣诞树①
c语言·开发语言·c++