Leetcode第56题(合并区间)

简介: 这篇文章介绍了LeetCode第56题“合并区间”的解题方法,通过排序和贪心策略合并重叠区间,并提供了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] 可被视为重叠区间。

示例: intervals = [[1,3],[9,12],[2,6],[8,13],[15,18]]

遍历整个数组

遍历过程之中会出现三种情况:

class Solution {
public:
    vector<vector<int>> merge(vector<vector<int>>& intervals) {
        //定义结果变量
        vector<vector<int>> ans;
        //排序
        sort(intervals.begin(),intervals.end());
        //定义一个区间的开始位置和结果位置
        int start = intervals[0][0],end = intervals[0][1];
        //遍历
        for(int i = 1; i< intervals.size();i++){
            //当前区间end < 下一个区间start (没有重叠部分)
            if(intervals[i][0] > end){
                ans.push_back({start,end});
                start = intervals[i][0];
                end = intervals[i][1];
            }else{          //有重叠部分
                end = max(end,intervals[i][1]);
            }
        }
        ans.push_back({start,end});

        return ans;
    }
};
相关文章
|
8月前
|
C++ Python
leetcode-56:合并区间
leetcode-56:合并区间
64 0
|
3月前
acwing 836 合并区间
acwing 836 合并区间
16 1
acwing 836 合并区间
|
3月前
|
算法
Leetcode第57题(插入区间)
LeetCode第57题“插入区间”的解题方法,包括题目描述、示例、算法思路和代码实现,旨在解决将新区间插入有序且不重叠的区间列表中,并合并重叠区间的问题。
27 0
Leetcode第57题(插入区间)
|
5月前
|
算法
LeetCode第56题合并区间
LeetCode第56题"合并区间"的解题方法,通过排序区间并判断重叠后进行合并,有效解决了区间合并问题。
LeetCode第56题合并区间
|
5月前
|
算法
LeetCode第57题插入区间
LeetCode第57题"插入区间"的解题方法,利用原区间集有序的特性,通过三步插入操作,有效实现了新区间的插入和重叠区间的合并。
LeetCode第57题插入区间
|
7月前
|
存储 算法 测试技术
力扣经典150题第四十八题:合并区间
力扣经典150题第四十八题:合并区间
88 0
|
8月前
力扣56.合并区间
力扣56.合并区间
|
8月前
代码随想录Day30 贪心05 LeetCode T435无重叠区间 T763划分字母区间 T56 合并区间
代码随想录Day30 贪心05 LeetCode T435无重叠区间 T763划分字母区间 T56 合并区间
56 0
|
8月前
leetcode-57:插入区间
leetcode-57:插入区间
61 0
|
算法 安全 Swift
LeetCode - #57 插入区间
不积跬步,无以至千里;不积小流,无以成江海,Swift社区 伴你前行。如果大家有建议和意见欢迎在文末留言,我们会尽力满足大家的需求。
LeetCode - #57 插入区间