夸父追日:第八章 贪心算法 part05

今日收获:合并区间,单调递增的数字,监控二叉树

1. 合并区间

题目链接:56. - 力扣(LeetCode)

思路:

(1)局部最优:将区间靠左排序,每次合并都取最大的右区间。

(2)记录初始的左右区间,如果遍历到重叠区间,更新右区间为重叠区间中最长的右区间;如果没有重叠,就添加重叠区间的起始位置到结果中,再更新起始位置为当前区间的起始位置。注意遍历结束后需要再添加一次区间的起始位置。

方法:

java 复制代码
class Solution {
    public int[][] merge(int[][] intervals) {
        // 向左排序
        Arrays.sort(intervals,(a,b)->Integer.compare(a[0],b[0]));

        List<int[]> result=new ArrayList<>();
        int left=intervals[0][0];
        int rightMostBound=intervals[0][1];
        for (int i=1;i<intervals.length;i++){
            // 重叠区间
            if (intervals[i][0]<=rightMostBound){
                rightMostBound=Math.max(intervals[i][1],rightMostBound);  // 扩展重叠区间
            }else{  // 不重叠
                result.add(new int[]{left,rightMostBound});
                left=intervals[i][0];
                rightMostBound=intervals[i][1];
            }
        }
        result.add(new int[]{left,rightMostBound});
        return result.toArray(new int[result.size()][]);
    }
}

总结:自己的代码能力还是不够,有的时候思路大体对了,但是代码中有很多的小错误。

2. 单调递增的数字

题目链接:738. - 力扣(LeetCode)

思路:

(1)局部最优:如果发现前后两位不满足顺序要求,就将前一位减一,后一位取9

(2)从后往前遍历数字,如果后一位大于前一位,就更新变为9的位置,前一位减一。利用flag记录变为9的位置是为了"1000"这样的用例。

方法:

java 复制代码
class Solution {
    public int monotoneIncreasingDigits(int n) {
        String str=String.valueOf(n);
        char[] chars=str.toCharArray();
        
        int len=chars.length;
        int flag=len;  // 变为9的位置

        // 从后向前遍历
        for (int i=len-1;i>0;i--){
            if (chars[i-1]>chars[i]){
                chars[i-1]--;
                flag=i;
            }
        }

        // 赋值为9
        for (int i=flag;i<len;i++){
            chars[i]='9';
        }

        return Integer.parseInt(new String(chars));
    }
}

总结:int类型转换为String类型,方法String.valueOf(n),需要总结到String常用方法中

3. 监控二叉树

题目链接:968. - 力扣(LeetCode)

思路:从下往上遍历,在叶子节点的父节点上放摄像头,然后再每隔两个节点放一个摄像头,这样可以省下更多的摄像头。

二刷一定可以啃下来!

相关推荐
如君愿1 分钟前
考研复习 Day 24 | 习题--计算机网络第二章(物理层)、数据结构(栈与队列)
数据结构·计算机网络·考研·课后习题·记录考研
一只数据集2 分钟前
机器学习多领域综合数据集分析-包含基因表达时间序列分类回归数据-适用于算法训练模型评估科研应用
人工智能·算法·数据分析
MY_TEUCK2 分钟前
【Maven基础】Maven从安装配置到依赖管理与生命周期(可复现+避坑+面试)
java·面试·maven
huipeng9264 分钟前
分布式服务部署详解
java·开发语言·spring cloud·微服务
秦歌6665 分钟前
RAG-6-高级RAG实战案例:自适应路由 + 自评估重写 + 网络回退
java·服务器·前端·人工智能·python
c++之路9 分钟前
C++ 命名空间(Namespace)
开发语言·c++·算法
jiang_bluetooth1 小时前
奈奎斯特第一准则理解和WIFI OFDM的关联
算法
极客先躯1 小时前
高级java每日一道面试题-2025年11月17日-容器与虚拟化题[Dockerj]-请解释容器和虚拟机的本质区别,从架构层面详细说明。
java·docker·架构
雨奔8 小时前
Kubernetes DNS 完全指南:服务发现核心机制与实践
java·kubernetes·服务发现
DuHz8 小时前
论文精读:大语言模型 (Large Language Models, LLM) —— 一项调查
论文阅读·人工智能·深度学习·算法·机器学习·计算机视觉·语言模型