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

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

相关推荐
CodeSheep程序羊7 分钟前
拼多多春节加班工资曝光,没几个敢给这个数的。
java·c语言·开发语言·c++·python·程序人生·职场和发展
独好紫罗兰7 分钟前
对python的再认识-基于数据结构进行-a002-列表-列表推导式
开发语言·数据结构·python
2401_8414956412 分钟前
【LeetCode刷题】二叉树的直径
数据结构·python·算法·leetcode·二叉树··递归
budingxiaomoli12 分钟前
优选算法-字符串
算法
我是咸鱼不闲呀27 分钟前
力扣Hot100系列19(Java)——[动态规划]总结(上)(爬楼梯,杨辉三角,打家劫舍,完全平方数,零钱兑换)
java·leetcode·动态规划
qq74223498431 分钟前
APS系统与OR-Tools完全指南:智能排产与优化算法实战解析
人工智能·算法·工业·aps·排程
数智工坊37 分钟前
【数据结构-树与二叉树】4.5 线索二叉树
数据结构
加油,小猿猿1 小时前
Java开发日志-双数据库事务问题
java·开发语言·数据库
A尘埃1 小时前
超市购物篮关联分析与货架优化(Apriori算法)
算法
.小墨迹1 小时前
apollo学习之借道超车的速度规划
linux·c++·学习·算法·ubuntu