海智算法训练营第三十五天 | 第八章 贪心算法 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

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

相关推荐
XiaoLeisj27 分钟前
【递归,搜索与回溯算法 & 综合练习】深入理解暴搜决策树:递归,搜索与回溯算法综合小专题(二)
数据结构·算法·leetcode·决策树·深度优先·剪枝
禁默39 分钟前
深入浅出:AWT的基本组件及其应用
java·开发语言·界面编程
Cachel wood1 小时前
python round四舍五入和decimal库精确四舍五入
java·linux·前端·数据库·vue.js·python·前端框架
Jasmine_llq1 小时前
《 火星人 》
算法·青少年编程·c#
Code哈哈笑1 小时前
【Java 学习】深度剖析Java多态:从向上转型到向下转型,解锁动态绑定的奥秘,让代码更优雅灵活
java·开发语言·学习
gb42152871 小时前
springboot中Jackson库和jsonpath库的区别和联系。
java·spring boot·后端
程序猿进阶1 小时前
深入解析 Spring WebFlux:原理与应用
java·开发语言·后端·spring·面试·架构·springboot
闻缺陷则喜何志丹1 小时前
【C++动态规划 图论】3243. 新增道路查询后的最短距离 I|1567
c++·算法·动态规划·力扣·图论·最短路·路径