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;
}
};