zoukankan      html  css  js  c++  java
  • 【LeetCode 57】插入区间

    题目链接

    【题解】

    这题要分四种情况。 第一种。区间在所有区间的前面。 第二种。区间在所有区间的后面。 第三种。区间在某两个区间之间但是没有交集。 第四种。区间和某个区间产生了相交。 对于第四种枚举第一次产生相交的区间是哪一个。 然后往后尝试延伸。看看会不会合并更多区间。

    【代码】

    class Solution {
    public:
        vector<vector<int>> insert(vector<vector<int>>& intervals, vector<int>& newInterval) {
            vector<vector<int>> ans;ans.clear();
            vector<int> temp;temp.resize(2);
            int len = intervals.size();
            //在所有区间前面
            if (!intervals.empty() && newInterval[1]<intervals[0][0]){
                ans.push_back(newInterval);
                for (int i = 0;i<len;i++) ans.push_back(intervals[i]);
                return ans;
            }
            //在区间之间但是没有交集。
            for (int i = 0;i < len-1;i++){
                ans.push_back(intervals[i]);
                if (intervals[i][1]<newInterval[0] &&
                    newInterval[1]<intervals[i+1][0]){
                        ans.push_back(newInterval);
                        for (int j = i+1;j<len;j++){
                            ans.push_back(intervals[j]);
                        }
                        return ans;
                    }
            }
            ans.clear();
            //区间和某些原来的区间产生了交集。
            for (int i = 0;i < len;i++){
                if (intervals[i][1]>=newInterval[0]){
                    int l = min(intervals[i][0],newInterval[0]);
                    int r = max(intervals[i][1],newInterval[1]);
                    while (i+1<len && intervals[i+1][0]<=r){
                        r = max(r,intervals[i+1][1]);
                        i++;
                    }
                    temp[0] = l;temp[1] = r;
                    ans.push_back(temp);
                    for (int j = i+1;j<len;j++) ans.push_back(intervals[j]);
                    return ans;
                }else{
                    temp = intervals[i];
                    ans.push_back(temp);
                }
            }
            ans.push_back(newInterval);
            return ans;
        }
    };
    
  • 相关阅读:
    过滤器
    包装 request Demo
    分页思路
    导出数据库中所有数据到Excle中
    负载均衡集群中的session解决方案
    python 自动化之路 day 01 人生若只如初见
    python 自动化之路 day 00 目录
    切割TOMCAT日志
    Java进程CPU使用率高排查
    使用socket方式连接Nginx优化php-fpm性能
  • 原文地址:https://www.cnblogs.com/AWCXV/p/11890566.html
Copyright © 2011-2022 走看看