C++速通LeetCode中等第9题-合并区间

排序后迭代,遇到符合条件的就删除前一项,合并到后一项。

cpp 复制代码
class Solution {
public:
    vector<vector<int>> merge(vector<vector<int>>& intervals) {
        int left = 0,right = 0;
        sort(intervals.begin(), intervals.end());
        vector<int> tmp;
        for(auto it = intervals.begin(); it != --(intervals.end()); )
        {
            if((*it)[1] >= (*(++it))[0])
            {
                left = (*(--it))[0];
                right = (*it)[1];
                it = intervals.erase(it);
                right = max(right,(*it)[1]);
                tmp.push_back(left);
                tmp.push_back(right);
                *(it) = tmp;
                tmp.clear();
            }
        }
        return intervals;
    }
};
相关推荐
zmzb01035 分钟前
C++课后习题训练记录Day104
开发语言·c++
honiiiiii17 分钟前
SMU winter week4
c++
踩坑记录34 分钟前
递归回溯本质
leetcode
zmzb010343 分钟前
C++课后习题训练记录Day105
开发语言·c++·算法
wjs202444 分钟前
Vue3 条件语句
开发语言
_codemonster1 小时前
JavaWeb开发系列(六)JSP基础
java·开发语言
闻缺陷则喜何志丹1 小时前
【拆位法】P8743 [蓝桥杯 2021 省 A] 异或数列|普及+
c++·蓝桥杯·位运算·拆位法
好学且牛逼的马1 小时前
【Hot100|25-LeetCode 142. 环形链表 II - 完整解法详解】
算法·leetcode·链表
fpcc1 小时前
跟我学C++中级篇——Concepts的循环依赖
c++·模板和元编程
Web打印1 小时前
Phpask(php集成环境)之16 怎样彻底停用一个网站
开发语言·php