代码随想录算法训练营第三十六天 _ 贪心算法_435.无重叠区间、763.划分字母区间、56.合并区间。

学习目标:

60天训练营打卡计划!

学习内容:

435.无重叠区间

  • 与452有异曲同工之妙!
  • 掌握Integer自带的比较方法:Integer.compare(a,b); --- 可以避免int比较时的溢出。
java 复制代码
class Solution {
    public int eraseOverlapIntervals(int[][] intervals) {
        int res = 0;
        Arrays.sort(intervals,(a, b) -> Integer.compare(a[0], b[0]));

        for(int i = 1; i < intervals.length; i++){
            if(intervals[i][0] < intervals[i-1][1]){
                res++;
                intervals[i][1] = Math.min(intervals[i-1][1], intervals[i][1]);
            }
        }
        return res;
    }
}

763.划分字母区间

  • 心得:carl哥的各种小技巧用的出神入化,太牛辣!
  • 第一步给数组中的元素附最远的位置值的思路就不是很好想,或者说没接触过的根本想不到,太巧妙了!
  • 第二步中使用双指针来限定每个组的范围也是非常的妙!虽然想着不是很好理解,但确实行之有效。
java 复制代码
class Solution {
    public List<Integer> partitionLabels(String s) {
        int[] hash = new int[26];
        // 给数组中的元素附最远位置值
        for(int i = 0; i < s.length(); i++){
            hash[s.charAt(i) - 'a'] = i;
        }

        List<Integer> res = new ArrayList<>();
        int start = 0;
        int end = 0;
        for(int i = 0; i < s.length(); i++){
            // 限定数组的结束位置
            end = Math.max(end, hash[s.charAt(i) - 'a']);
            if(i == end){
                res.add(i-start+1);
                start = i+1;
                if(start >= s.length())  break;
            }
        } 
        return res;
    }
}

56.合并区间

  • 和435与452思路基本相似,可以轻松拿下!
java 复制代码
class Solution {
    public int[][] merge(int[][] intervals) {
        Arrays.sort(intervals, (a, b) -> Integer.compare(a[0], b[0]));
        // 要学会这个骚操作,可以定义为List<int[]>,然后使用toArray方法就可以变为int[][]
        List<int[]> res = new ArrayList<>();
        for(int i = 1; i < intervals.length; i++){
            if(intervals[i][0] > intervals[i-1][1])
                res.add(intervals[i-1]);
            else{
                intervals[i][1] = Math.max(intervals[i-1][1], intervals[i][1]);
                intervals[i][0] = Math.min(intervals[i-1][0], intervals[i][0]);
                intervals[i-1][0] = -1;
                intervals[i-1][1] = -1;
            }
        }
        res.add(intervals[intervals.length - 1]);
        
        return res.toArray(new int[res.size()][]);
    }
}

学习时间:

  • 上午两小时,下午一小时,整理文档半小时。
相关推荐
熊猫_豆豆4 分钟前
YOLOP车道检测
人工智能·python·算法
艾莉丝努力练剑18 分钟前
【Linux:文件】Ext系列文件系统(初阶)
大数据·linux·运维·服务器·c++·人工智能·算法
偷吃的耗子1 小时前
【CNN算法理解】:CNN平移不变性详解:数学原理与实例
人工智能·算法·cnn
dazzle2 小时前
机器学习算法原理与实践-入门(三):使用数学方法实现KNN
人工智能·算法·机器学习
那个村的李富贵2 小时前
智能炼金术:CANN加速的新材料AI设计系统
人工智能·算法·aigc·cann
张张努力变强2 小时前
C++ STL string 类:常用接口 + auto + 范围 for全攻略,字符串操作效率拉满
开发语言·数据结构·c++·算法·stl
万岳科技系统开发2 小时前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
张登杰踩2 小时前
MCR ALS 多元曲线分辨算法详解
算法
YuTaoShao2 小时前
【LeetCode 每日一题】3634. 使数组平衡的最少移除数目——(解法一)排序+滑动窗口
算法·leetcode·排序算法
波波0072 小时前
每日一题:.NET 的 GC是如何分代工作的?
算法·.net·gc