贪心算法---无重叠区间

题目:给定一个区间的集合 intervals ,其中 intervals[i] = [starti, endi] 。返回 需要移除区间的最小数量,使剩余区间互不重叠

思路:将intervals数组按照左边界从小到大进行排序,用count记录无交叉的区间数量。遍历数组,如果正在遍历的区间与上一个区间有重叠,则将该区间的右边界更新为两个区间的最小右边界。如果正在遍历的区间与上一个区间无重叠,则count+1。最后用数组长度减去count就是无重叠区间数量。

代码:

java 复制代码
    public int eraseOverlapIntervals(int[][] intervals) {
        Arrays.sort(intervals,(a,b)->Integer.compare(a[0],b[0]));
        int count=1;//记录非交叉区间数量
        for(int i=1;i<intervals.length;i++){
            if(intervals[i][0]>=intervals[i-1][1]){//两个区间不重叠
                count++;
            }
            else{;//如果重叠,则把右边界改为这两个区间的最小右边界
                intervals[i][1]=Math.min(intervals[i][1],intervals[i-1][1]);
            }
        }
        return intervals.length-count;
    }
相关推荐
Ka1Yan10 分钟前
[链表] - 代码随想录 160. 相交链表
算法·leetcode·链表
Ka1Yan12 分钟前
[链表] - 代码随想录 206. 反转链表
数据结构·链表
学嵌入式的小杨同学16 分钟前
C 语言实战:动态规划求解最长公共子串(连续),附完整实现与优化
数据结构·c++·算法·unity·游戏引擎·代理模式
rgeshfgreh19 分钟前
顺序表实战:构建到销毁全解析
算法
十八岁讨厌编程21 分钟前
【算法训练营Day32】图论专题
算法·深度优先·图论
小欣加油27 分钟前
leetcode 174 地下城游戏
c++·算法·leetcode·职场和发展·动态规划
sali-tec38 分钟前
C# 基于OpenCv的视觉工作流-章11-高斯滤波
图像处理·人工智能·opencv·算法·计算机视觉
良木生香41 分钟前
【C语言进阶】文件操作的相关详解(1):
c语言·数据结构·c++
Ka1Yan1 小时前
[链表] - 代码随想录 203. 移除链表元素
数据结构·链表
不知名XL1 小时前
day23 贪心算法 part01
算法·贪心算法