代码随想录算法训练营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;
    }
};

相关推荐
小欣加油几秒前
leetcode3635 最早完成陆地和水上游乐设施的时间II
数据结构·c++·算法·leetcode
QT-Neal9 分钟前
链接和库整理
c++
剑锋所指,所向披靡!17 分钟前
C++多线程实现
开发语言·c++·chrome
GUO_PP24 分钟前
win11英雄联盟打开以后,自动改变音效,开启免提模式的问题修正
人工智能·算法
十五年专注C++开发24 分钟前
Qt之QScopedPointer、QScopeGuard、QScopedValueRollback使用及源码解读
开发语言·c++·qt·qscopedpointer·qscopeguard
变量未定义~36 分钟前
排列数字、 n-皇后问题
数据结构·算法
thisiszdy43 分钟前
<C++> 多线程基础
c++
·白小白1 小时前
C++ STL 容器 list 底层结构详解
开发语言·c++·list
BirdenT1 小时前
20260604紫题训练
c++·算法
元启数宇1 小时前
疏散指示AI实战:规范布点与路径推演全流程
人工智能·算法