Day37 贪心算法part06

单调递增的数字

python 复制代码
class Solution:
    def monotoneIncreasingDigits(self, n: int) -> int:
        
        nl = [int(char) for char in str(n)]

        for i in range(len(nl)-1, 0, -1):
            if nl[i-1] > nl[i]:
                nl[i-1] -= 1
                nl[i] = 9
                for j in range(i, len(nl)):
                    nl[j] = 9
                
        return int("".join(str(x) for x in nl))

前面都想到了,结果最后ni给写错了直接写成9了,得把后面的全都改成9才行

监控二叉树

摄像头的覆盖范围是上中下

遇到叶子结点,放到叶子结点的父节点

每隔两个空节点放一个摄像头

所以要用后序遍历

把结点分为三个状态:0无覆盖1有摄像头2有覆盖

空节点要设置为有覆盖的状态

太难劝退

相关推荐
西安邮电大学12 分钟前
分治算法详细讲解
java·后端·其他·算法·面试
code bean16 分钟前
平衡相关性与多样性:推荐系统中的永恒博弈与 MMR 算法详解
算法
青梅橘子皮23 分钟前
Linux---进程控制(2)(进程程序替换)
linux·c++·算法
Shan120526 分钟前
经典问题——验证栈序列
数据结构·算法
2501_9065651238 分钟前
勾股定理证明
算法
Shan12051 小时前
无向图的Hierholzer算法流程(二)
算法
gihigo19981 小时前
基于蒙特卡洛的异常值剔除(RANSAC + MC置信区间)—MATLAB实现
开发语言·算法·matlab
Asize2 小时前
数组数据结构底层:从灵活到陷阱
前端·javascript·算法
hairenwangmiao2 小时前
B4041 [GESP202409 四级] 区间排序
算法·排序
人道领域2 小时前
【LeetCode刷题日记】47.全排列Ⅱ
java·开发语言·算法·leetcode