代码随想录算法训练营Day35 | 435. 无重叠区间 763.划分字母区间 56. 合并区间
LeetCode 435. 无重叠区间
题目链接:LeetCode 435. 无重叠区间
思路:
左排序,统计 重合区域,并记录右区间最小值
cpp
class Solution {
public:
bool static cmp(vector<int>& a , vector<int>& b){
//if(a[0] == b[0]) return a[1] < b[1];
return a[0] < b[0];
}
int eraseOverlapIntervals(vector<vector<int>>& intervals) {
if(intervals.size()==1) return 0;
sort(intervals.begin(), intervals.end());
int count = 0;
for(int i = 1; i<intervals.size(); i++){
if(intervals[i][0] < intervals[i-1][1]) {
count++;
intervals[i][1] = min(intervals[i][1], intervals[i-1][1]);
}
}
return count;
}
};
注意 :
- 注意是在重叠时判断右区间的最小值
LeetCode 763.划分字母区间
题目链接:LeetCode 763.划分字母区间
思路:
用hash表记录最右区间,再滑动最右区间即可。
cpp
class Solution {
public:
vector<int> partitionLabels(string s) {
int hash[]27,0);
vector<int> res;
for(int i=0; i<s.size(); i++){
hash[s[i]-'a'] = i;
}
int left = 0;
int right = 0;
for(int i=0; i < s.size(); i++){
right = max(hash[s[i]-'a'], right);
if(i==right){
res.push_back(right-left+1);
left = i+1;
}
}
return res;
}
};
注意 :
- 需要单独一个index遍历数组
LeetCode 56. 合并区间
题目链接:LeetCode 56. 合并区间
思路:
左区间排序,变化右区间,取最大值
cpp
class Solution {
public:
bool static cmp (vector<int>& a, vector<int>& b){
return a[0] < b[0];
}
vector<vector<int>> merge(vector<vector<int>>& intervals) {
vector<vector<int>> res;
sort(intervals.begin(), intervals.end(), [](vector<int>& a, vector<int>& b){return a[0] < b[0];});
res.push_back(intervals[0]);
for(int i = 1; i < intervals.size(); i++){
if(intervals[i][0] <= res.back()[1]){
res.back()[1] = max(intervals[i][1], res.back()[1]);
}
else{
res.push_back(intervals[i]);
}
}
return res;
}
};
注意 :
- 可用lambda表达式写cmp函数