leetcode57. 插入区间

1、题目

https://leetcode-cn.com/problems/insert-interval/submissions/

2、题意

题解1:将新加的数字加到数组里 排序和 上一题leetcode56做法一样;
执行用时:96 ms, 在所有 C++ 提交中击败了11.08%的用户
内存消耗:10.7 MB, 在所有 C++ 提交中击败了100.00%的用户

class Solution {
public:
    vector<vector<int>> insert(vector<vector<int>>& intervals, vector<int>& newInterval) {
        vector<vector<int>> res;
        intervals.push_back(newInterval);
        
        int maxn,n = intervals.size(),j = 0;
        for(int i=0;i<n;)
        {
            maxn = intervals[i][1];
            j = i+1;
            while(j<n&&intervals[j][0]<=maxn)
            {
                maxn = max(maxn,intervals[j][1]);
                j++;
            }
            res.push_back({intervals[i][0],maxn});
            i = j;
        }
        return res;
    }
};

题解2 : 将数组分成三段
第一段与新加的数组没有交集且在新加数组的左边
第二段与新加数组有交集
第三段与新加数组没有交集且在新加数组的右边
ps:[[1,2],[3,5],[6,7],[8,10],[12,16]]
[4,8]
可分为 1,2 = 1,2
3,5 4,8 6,7 8,10 = 3,10
12,16 = 12,16
执行用时:20 ms, 在所有 C++ 提交中击败了81.61%的用户
内存消耗:10.3 MB, 在所有 C++ 提交中击败了100.00%的用户

class Solution {
public:
    vector<vector<int>> insert(vector<vector<int>>& a, vector<int>& b) {
        vector<vector<int>> res;
        int k = 0;
        while(k<a.size()&&a[k][1]<b[0])
            res.push_back(a[k++]);
        if(k<a.size())
        {
            b[0] = min(b[0],a[k][0]);
            while(k<a.size()&&a[k][0]<=b[1]) b[1] = max(a[k++][1],b[1]);
        }
        res.push_back(b);
        while(k<a.size()) res.push_back(a[k++]);
        return res;
    }
};

你可能感兴趣的:(leetcode,leetcode)