海智算法训练营第三十五天 | 第八章 贪心算法 part05 | ● 435. 无重叠区间 ● 763.划分字母区间 ● 56. 合并区间

今日任务:

1.非重叠区间问题(和气球一样)

2.划分字母区间

3.合并区间

1.非重叠区间问题(和气球一样)

力扣题目链接

和射气球一样的做法,经典重叠区间基础问题

复制代码
class Solution {
    public int eraseOverlapIntervals(int[][] intervals) {
        int sum = 0;
        Arrays.sort(intervals , (o1,o2) -> Integer.compare(o1[0],o2[0]));
        for (int i = 1; i < intervals.length; i++) {
            if(intervals[i][0] >= intervals[i-1][1])    continue;
            else{
                sum++;
                intervals[i][1] = Math.min(intervals[i][1] , intervals[i-1][1]);
            }
        }
        return sum;
    }
}

2.划分字母区间

力扣题目链接

这道题也很好想,先记录每个字母对应的最远的下标,然后每次循环不断更新右边界,直到循环到i等于右边界的时候就找到了一个边界,放入res集合就好了。

复制代码
class Solution {
    public List<Integer> partitionLabels(String s) {
        List<Integer> res = new ArrayList<>();
        int left = 0 , right = 0;
        int[] hash = new int[26];
        char[] str = s.toCharArray();
        for (int i = 0; i < str.length; i++) {
            hash[str[i] - 'a'] = i;
        }
        for (int i = 0; i < str.length; i++) {
            right = Math.max(hash[str[i] - 'a'] , right);
            if (i == right){
                res.add((right - left + 1));
                left = i+1;
            }
        }
        return res;
    }
}

3.合并区间

力扣题目链接

这道题也很好理解,相当于前两题的结合体,这里多用了一个left指针来记录最左边界

注意点:用此方法最后会有个left、right组合没有添加,要记得添加。

复制代码
class Solution {
    public int[][] merge(int[][] intervals) {
        List<int[]> res = new ArrayList<>();
        Arrays.sort(intervals , (o1,o2) -> Integer.compare(o1[0],o2[0]));
        int left = intervals[0][0] , right = intervals[0][1];
        for (int i = 1; i < intervals.length ; i++) {
            if(intervals[i][0] > right){
                res.add(new int[]{left , right});
                left = intervals[i][0] ;
                right = intervals[i][1];
            }else{
                right = Math.max(right , intervals[i][1]);
            }
        }
        res.add(new int[]{left,right});
        return res.toArray(new int[res.size()][]);
    }
}

学习时长:2h

总结:此次学习了关于重叠区间更深的知识,对重叠区间类的题目更加的熟悉。

相关推荐
im_AMBER2 分钟前
Leetcode 103 反转链表 II
数据结构·c++·笔记·学习·算法·leetcode
人道领域4 分钟前
【零基础学java】(TCP协议)
java·开发语言·tcp/ip
rgeshfgreh6 分钟前
回溯算法精解:排列、子集与组合
python·算法·深度优先
老毛肚12 分钟前
Spring源码探究2.0
java·后端·spring
Star Learning Python16 分钟前
30道经典java面试题
java·开发语言
Ka1Yan21 分钟前
[链表] - 代码随想录 24. 两两交换链表中的节点
数据结构·链表
rit843249927 分钟前
有限元算法求解铁木辛柯梁梁静力问题实例
算法
智驱力人工智能29 分钟前
矿山皮带锚杆等异物识别 从事故预防到智慧矿山的工程实践 锚杆检测 矿山皮带铁丝异物AI预警系统 工厂皮带木桩异物实时预警技术
人工智能·算法·安全·yolo·目标检测·计算机视觉·边缘计算
运维@小兵30 分钟前
Spring AI入门
java·人工智能·spring