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

相关推荐
Byron Loong1 小时前
【c++】为什么有了dll和.h,还需要包含lib
java·开发语言·c++
Dlrb12111 小时前
C语言-指针数组与数组指针
c语言·数据结构·算法·指针·数组指针·指针数组·二级指针
WL_Aurora1 小时前
Python 算法基础篇之集合
python·算法
坚果派·白晓明1 小时前
【鸿蒙PC三方库移植适配框架解读系列】第一篇:Lycium C/C++ 三方库适配 — 概述与环境配置
c语言·开发语言·c++·harmonyos·开源鸿蒙·三方库·c/c++三方库
平行侠1 小时前
A15 工业路由器IP前缀高速检索与内存压缩系统
网络·tcp/ip·算法
咩咦2 小时前
C++学习笔记02:cin 和 cout 输入输出
c++·学习笔记·cin·输入输出·cout
咩咦2 小时前
C++学习笔记05:引用和常引用
c++·学习笔记·引用·const·常引用
香蕉鼠片3 小时前
算法过程中不会的
开发语言·c++
阿旭超级学得完3 小时前
C++11包装器(function和bind)
java·开发语言·c++·算法·哈希算法·散列表
li星野3 小时前
位运算 & 数学 & 高频进阶九题通关(Python + C++)
c++·python·学习·算法