Re: [闲聊] 每日LeetCode

楼主: yam276 ('_')   2023-07-19 16:20:03
https://leetcode.com/problems/non-overlapping-intervals/submissions/
435. Non-overlapping Intervals
Given an array of intervals intervals where intervals[i] = [starti, endi],
return the minimum number of intervals you need to remove to make the rest of
the intervals non-overlapping.
给一堆区间 要你算删掉几个区间会让他们不重叠
Example 1:
Input: intervals = [[1,2],[2,3],[3,4],[1,3]]
Output: 1
Explanation: [1,3] can be removed and the rest of the intervals are non-
overlapping.
Example 2:
Input: intervals = [[1,2],[1,2],[1,2]]
Output: 2
Explanation: You need to remove two [1,2] to make the rest of the intervals
non-overlapping.
Example 3:
Input: intervals = [[1,2],[2,3]]
Output: 0
Explanation: You don't need to remove any of the intervals since they're
already non-overlapping.
Step:
0. Vec.len() = 0 判断
1. 先根据区间尾排列Vec
2. 设result = 1代表不重复区间数,设last_tail来当目前区间的尾
3. 前后区间不重叠(后者head >= 前者tail)则result+1
4. return 区间数减不重复区间数
只算重叠区间也可以 就反过来写
Code:
impl Solution
{
pub fn erase_overlap_intervals(intervals: Vec<Vec<i32>>) -> i32
{
if intervals.is_empty()
{
return 0;
}
let mut intervals = intervals;
intervals.sort_by(|a, b| a[1].cmp(&b[1]));
let mut result = 1;
let mut last_tail = intervals[0][1];
for pair_nums in intervals.iter()
{
if(pair_nums[0] >= last_tail)
{
last_tail = pair_nums[1];
result += 1;
}
}
return (intervals.len() - result) as i32;
}
}
等价于:
class Solution
{
public:
int eraseOverlapIntervals(vector<vector<int>>& intervals)
{
if (intervals.size() < 1)
return 0;
std::sort(intervals.begin(), intervals.end(),
[](vector<int>& a, vector<int>& b)
{
return a[1] < b[1];
});
int result = 0;
int last_tail = intervals[0][1];
for (auto& pair_nums : intervals)
{
if (pair_nums[0] >= last_tail)
{
last_tail = pair_nums[1];
result++;
}
}
return intervals.size() - result;
}
};
作者: Rushia (みけねこ的鼻屎)   2023-07-19 16:21:00
大师
作者: sustainer123 (caster)   2023-07-19 16:26:00
大师

Links booklink

Contact Us: admin [ a t ] ucptt.com