435. 无重叠区间

太过爱你忘了你带给我的痛 2023-10-16 15:38 227阅读 0赞

435. 无重叠区间

  • 题干描述
  • 解题思路
  • 补充
  • 代码实现

题干描述

力扣入口

给定一个区间的集合,找到需要移除区间的最小数量,使剩余区间互不重叠。

注意: 可以认为区间的终点总是大于它的起点。 区间 [1,2] 和 [2,3] 的边界相互“接触”,但没有相互重叠。

示例 1:

  • 输入: [ [1,2], [2,3], [3,4], [1,3] ]
  • 输出: 1
  • 解释: 移除 [1,3] 后,剩下的区间没有重叠。

示例 2:

  • 输入: [ [1,2], [1,2], [1,2] ]
  • 输出: 2
  • 解释: 你需要移除两个 [1,2] 来使剩下的区间没有重叠。

示例 3:

  • 输入: [ [1,2], [2,3] ]
  • 输出: 0
  • 解释: 你不需要移除任何区间,因为它们已经是无重叠的了。

解题思路

相信很多同学看到这道题目都冥冥之中感觉要排序,但是究竟是按照右边界排序,还是按照左边界排序呢?

其实都可以。主要就是为了让区间尽可能的重叠。

我来按照右边界排序,从左向右记录非交叉区间的个数。最后用区间总数减去非交叉区间的个数就是需要移除的区间个数了。

此时问题就是要求非交叉区间的最大个数。

这里记录非交叉区间的个数还是有技巧的,如图:
在这里插入图片描述
区间,1,2,3,4,5,6都按照右边界排好序。

当确定区间 1 和 区间2 重叠后,如何确定是否与 区间3 也重贴呢?

就是取 区间1 和 区间2 右边界的最小值,因为这个最小值之前的部分一定是 区间1 和区间2 的重合部分,如果这个最小值也触达到区间3,那么说明 区间 1,2,3都是重合的。

接下来就是找大于区间1结束位置的区间,是从区间4开始。那有同学问了为什么不从区间5开始?别忘了已经是按照右边界排序的了

区间4结束之后,再找到区间6,所以一共记录非交叉区间的个数是三个。

总共区间个数为6,减去非交叉区间的个数3。移除区间的最小数量就是3。

补充

本题其实和452.用最少数量的箭引爆气球非常像,弓箭的数量就相当于是非交叉区间的数量,只要把弓箭那道题目代码里射爆气球的判断条件加个等号(认为[0,1][1,2]不是相邻区间),然后用总区间数减去弓箭数量 就是要移除的区间数量了。

代码实现

  1. class Solution {
  2. // 453.无重叠区间
  3. public int eraseOverlapIntervals(int[][] intervals){
  4. Arrays.sort(intervals, (a, b) -> {
  5. return Integer.compare(a[0], b[0]);
  6. });
  7. int count = 1;
  8. for(int i = 1; i < intervals.length; i++){
  9. if(intervals[i][0] < intervals[i-1][1]){
  10. intervals[i][1] = Math.min(intervals[i - 1][1], intervals[i][1]);
  11. continue;
  12. }else{
  13. count++;
  14. }
  15. }
  16. return intervals.length - count;
  17. }
  18. }
  19. class Solution {
  20. // 453.无重叠区间 - 按左边排序,不管右边顺序。相交的时候取最小的右边
  21. public int eraseOverlapIntervals(int[][] intervals){
  22. Arrays.sort(intervals, (a, b) ->{
  23. return Integer.compare(a[0], b[0]);
  24. });
  25. int remove = 0;
  26. int pre = intervals[0][1];
  27. for(int i = 1; i < intervals.length; i++){
  28. if(pre > intervals[i][0]){
  29. remove++;
  30. pre = Math.min(pre, intervals[i][1]);
  31. }
  32. else pre = intervals[i][1];
  33. }
  34. return remove;
  35. }
  36. }

参考资料:代码随想录-435. 无重叠区间

发表评论

表情:
评论列表 (有 0 条评论,227人围观)

还没有评论,来说两句吧...

相关阅读

    相关 leetcode 435.重叠区间(java 贪心)

    d先根据各区间尾节点进行从小到大排序,然后依次判断下一个区间的开始节点是否大于上一个区间的结束节点,若大于,可留住,若是小于,则发生重叠,删去。这样就能保证尾节点小的留住,为后

    相关 leetcode435重叠空间

    给定一个区间的集合,找到需要移除区间的最小数量,使剩余区间互不重叠。 注意: 可以认为区间的终点总是大于它的起点。 区间 \[1,2\] 和 \[2,3\] 的边界相互