代码随想录算法训练营Day-31贪心算法 | 56. 合并区间、738. 单调递增的数字、968. 监控二叉树

由于本笔记编辑时保存前误触,导致内容消失,所以为节省时间采取简单写法重写。

56. 合并区间

思路:

  1. 结果为空 或当前区间和结果最后一个区间不重叠,则把当前区间加入结果

  2. 若当前区间和结果最后一个区间重叠,则更新最后一个区间的右边界为最大值;

cpp 复制代码
class Solution {
public:
    vector<vector<int>> merge(vector<vector<int>>& intervals) {
        sort(intervals.begin(), intervals.end());

        vector<vector<int>> res;
        for (const auto& interval : intervals) {
            if (res.empty() || res.back()[1] < interval[0]) {
                res.push_back(interval);
            } else {
                res.back()[1] = max(res.back()[1], interval[1]);
            }
        }
        return res;
    }
};

738. 单调递增的数字

思路:

从后往前找到处在最前面位置的不递增的数字

把该数字后面的数全置为9

cpp 复制代码
class Solution {
public:
    int monotoneIncreasingDigits(int n) {
        string str = to_string(n);
        int flag=str.size();
        for(int i=str.size()-1;i>0;i--){
            if(str[i-1]>str[i]){
                flag = i;
                str[i-1]--;
            }
        } 
        for(int i=flag;i<str.size();i++){
            str[i]='9';
        }
        return stoi(str);
    }
};

968. 监控二叉树

思路:

想到应该根据左右孩子的状态决定父节点的处理逻辑,所以用后序遍历(左右中)

三种节点状态:不被监控-0、装摄像头-1、被监控-2

三种处理逻辑:

1.左右孩子均为2,父节点为0(只需要在父节点的父节点装摄像头,否则就重复监控了)

2.左右孩子有一个为0,父节点为1(否则为0的子节点会被忽略)

3.左右孩子有一个为1,父节点为2

注:如果最后整棵树的父节点状态如果为0,将其置为1,否则会出现父节点本身没被监控的情况

cpp 复制代码
class Solution {
public:
    int result=0;
    int travseral(TreeNode* cur){
        if (cur==NULL) return 2;
        int left = travseral(cur->left);
        int right = travseral(cur->right);

        if(left==2 && right==2) return 0;
        if(left==0 || right==0){
            result++;
            return 1;          
        }
        if(left==1 || right==1) return 2;
        return -1;
    }
    int minCameraCover(TreeNode* root) {
        result=0;
        if(travseral(root) == 0) result++;
        return result;
    }
};

相关推荐
罗西的思考6 小时前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
CSharp精选营9 小时前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
美团技术团队10 小时前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法
用户8055336980316 小时前
不止三件套:QObject 属性系统全关键字与运行时反射!
c++·qt
To_OC1 天前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC1 天前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
BadBadBad__AK1 天前
线段树维护区间 k 次方和
c++·数学·算法·stl
卷无止境2 天前
Eigen 库如何借助 OpenMP 加速计算
c++·后端
_清歌2 天前
DSpark 深度解读:DeepSeek-V4 如何用「半自回归」把推理速度提升 85%
算法