day31 第八章 贪心算法 part05

56. 合并区间

先排序,再合并

python 复制代码
class Solution:
    def merge(self, intervals: List[List[int]]) -> List[List[int]]:
        intervals.sort(key=lambda x:x[0])

        merged = []
        # merged.append(intervals[0])
        for i in range(len(intervals)):
            if not merged or intervals[i][0]>merged[-1][1]:
                merged.append(intervals[i])
            else:
                merged[-1][1] = max(merged[-1][1], intervals[i][1])


        return merged

738.单调递增的数字

"本题只要想清楚个例,例如98,一旦出现strNum[i - 1] > strNum[i]的情况(非单调递增),首先想让strNum[i - 1]减一,strNum[i]赋值9,这样这个整数就是89。就可以很自然想到对应的贪心解法了。

想到了贪心,还要考虑遍历顺序,只有从后向前遍历才能重复利用上次比较的结果。

最后代码实现的时候,也需要一些技巧,例如用一个flag来标记从哪里开始赋值9。" ---《代码随想录》

python 复制代码
class Solution:
    def monotoneIncreasingDigits(self, n: int) -> int:
        str_n = list(str(n))
        flag = len(str_n)
        # print(str_n)
        # result = []
        for i in range(len(str_n)-1, 0, -1):
            if str_n[i] < str_n[i-1]:
                flag = i
                str_n[i-1] = chr(ord(str_n[i-1])-1)

        for i in range(flag, len(str_n)):
            str_n[i] = '9'
        return int(''.join(str_n))
                

968.监控二叉树 (可跳过)

思路:监控都不在叶子节点,所以从底向上遍历,后序遍历,分3种情况,最后根节点也要判断一下。

python 复制代码
# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
# 1有监控,0无覆盖,2有覆盖
class Solution:
    result = 0
    def traversal(self, node: Optional[TreeNode]) -> int:
        if not node:
            return 2

        left = self.traversal(node.left)
        right = self.traversal(node.right)

        if left == 0 or right == 0:
            self.result += 1
            return 1
        
        if left == 1 or right == 1:
            return 2
        
        if left == 2 and right == 2:
            return 0

       
    def minCameraCover(self, root: Optional[TreeNode]) -> int:
        self.result = 0
        if self.traversal(root)==0:
            self.result += 1
        return self.result
相关推荐
Miraitowa_cheems43 分钟前
LeetCode算法日记 - Day 34: 二进制求和、字符串相乘
java·算法·leetcode·链表·职场和发展
wan5555cn1 小时前
AI生成内容的版权问题解析与实操指南
人工智能·笔记·深度学习·算法·音视频
DDAshley1262 小时前
【PaddleOCR】从零开始训练自己的模型--详细教程
算法·计算机视觉
梁辰兴2 小时前
数据结构:查找
数据结构·算法·查找·顺序查找·折半查找·分块查找
Brookty3 小时前
【算法】双指针(一)移动零
学习·算法
THMAIL3 小时前
机器学习从入门到精通 - 循环神经网络(RNN)与LSTM:时序数据预测圣经
人工智能·python·rnn·算法·机器学习·逻辑回归·lstm
程序员Xu3 小时前
【LeetCode热题100道笔记】二叉树的直径
笔记·算法·leetcode
superlls3 小时前
(数据结构)哈希碰撞:线性探测法 vs 拉链法
算法·哈希算法·散列表
ShineWinsu3 小时前
对于单链表相关经典算法题:206. 反转链表及876. 链表的中间结点的解析
java·c语言·数据结构·学习·算法·链表·力扣