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

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

相关推荐
陈果然DeepVersion1 分钟前
Java大厂面试真题:Spring Boot+Kafka+AI智能客服场景全流程解析(十)
java·spring boot·ai·kafka·面试题·向量数据库·rag
但要及时清醒38 分钟前
ArrayList和LinkedList
java·开发语言
一叶飘零_sweeeet1 小时前
从测试小白到高手:JUnit 5 核心注解 @BeforeEach 与 @AfterEach 的实战指南
java·junit
摇滚侠1 小时前
Spring Boot3零基础教程,Reactive-Stream 四大核心组件,笔记106
java·spring boot·笔记
Z3r4y1 小时前
【代码审计】RuoYi-3.0 三处安全问题分析
java·web安全·代码审计·ruoyi-3.0
与遨游于天地1 小时前
Spring解决循环依赖实际就是用了个递归
java·后端·spring
陈果然DeepVersion1 小时前
Java大厂面试真题:Spring Boot+微服务+AI智能客服三轮技术拷问实录(六)
java·spring boot·redis·微服务·面试题·rag·ai智能客服
Coovally AI模型快速验证2 小时前
当视觉语言模型接收到相互矛盾的信息时,它会相信哪个信号?
人工智能·深度学习·算法·机器学习·目标跟踪·语言模型
BeingACoder2 小时前
【SAA】SpringAI Alibaba学习笔记(一):SSE与WS的区别以及如何注入多个AI模型
java·笔记·学习·saa·springai