hot100练习-11

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
class Solution:
    def buildTree(self, preorder: List[int], inorder: List[int]) -> Optional[TreeNode]:
        def recur(root, left, right):
            if left > right: return
            node = TreeNode(preorder[root])
            i = dic[preorder[root]]
            node.left = recur(root+1, left, i-1)
            node.right = recur(i-left+root+1, i+1, right)
            return node

        dic = {}
        for i in range(len(inorder)):
            dic[inorder[i]] = i
        return recur(0, 0, len(inorder) - 1)

这里用前序确定根节点位置,用中序确定left和right

  • ​​前序遍历(preorder)​​:根节点 → 左子树 → 右子树(第一个元素是根节点)

  • ​​中序遍历(inorder)​​:左子树 → 根节点 → 右子树(根节点左侧是左子树,右侧是右子树)

通过前序遍历确定根节点,然后在中序遍历中找到该根节点的位置,从而划分左右子树的范围,递归构建整棵树

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
class Solution:
    def mergeTrees(self, root1: Optional[TreeNode], root2: Optional[TreeNode]) -> Optional[TreeNode]:
        if not root1: return root2
        if not root2: return root1
        return TreeNode(root1.val+root2.val, self.mergeTrees(root1.left, root2.left), self.mergeTrees(root1.right, root2.right))
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
class Solution:
    def flatten(self, root: Optional[TreeNode]) -> None:
        """
        Do not return anything, modify root in-place instead.
        """
        if not root: return None
        left_tail = self.flatten(root.left)
        right_tail = self.flatten(root.right)
        if left_tail:
            left_tail.right = root.right
            root.right = root.left
            root.left = None
        return right_tail or left_tail or root

分别找到左右子树的末尾节点,然后连接左右节点并都放到右节点上

python 复制代码
class Solution:
    def leastInterval(self, tasks: List[str], n: int) -> int:
        cnt = Counter(tasks)
        nbucket = cnt.most_common(1)[0][1]
        last_bucket_size = list(cnt.values()).count(nbucket)
        res = (nbucket - 1) * (n + 1) + last_bucket_size
        return max(res, len(tasks))
        

设计桶大小为n+1,相同的任务不能放在同一个桶里面,然后对于重复的任务,我们只能将每个都放入不同的桶中,因此桶的个数就是重复次数最多的任务的个数。一个桶不管是否放满,其占用的时间均为 n+1,这是因为后面桶里的任务需要等待冷却时间。最后一个桶是个特例,由于其后没有其他任务需等待,所以占用的时间为桶中的任务个数。所以

总排队时间 = (桶个数 - 1) * (n + 1) + 最后一桶的任务数

last_bucket_size = list(ct.values()).count(nbucket)

计算有多少个任务和最高频任务一样频繁,就是最后一个桶肯定放的都是最高频任务,那么就是最后一个桶的任务数了。

python 复制代码
class Solution:
    def exist(self, board: List[List[str]], word: str) -> bool:
        m, n = len(board), len(board[0])
        def dfs(i, j, k):
            if not 0 <= i < m or not 0 <= j < n or board[i][j] != word[k]: return False
            if k == len(word) - 1: return True
            board[i][j] = ''
            res = dfs(i-1, j, k+1) or  dfs(i+1, j, k+1) or dfs(i, j+1, k+1) or dfs(i, j-1, k+1)
            board[i][j] = word[k]
            return res
        
        for i, row in enumerate(board):
            for j, e in enumerate(row):
                if dfs(i, j, 0): return True
        return False

判断,置空,递归,恢复,返回

相关推荐
代码雕刻家几秒前
C语言中关于类型转换不匹配的解决方案
c语言·开发语言·算法
星星的月亮叫太阳1 小时前
large-scale-DRL-exploration 代码阅读 总结
python·算法
王哈哈^_^1 小时前
YOLOv11视觉检测实战:安全距离测算全解析
人工智能·数码相机·算法·yolo·计算机视觉·目标跟踪·视觉检测
..Cherry..1 小时前
Etcd详解(raft算法保证强一致性)
数据库·算法·etcd
商汤万象开发者2 小时前
LazyLLM教程 | 第13讲:RAG+多模态:图片、表格通吃的问答系统
人工智能·科技·算法·开源·多模态
Lee_yayayayaya2 小时前
本原多项式产生m序列的原理
算法
蒙奇D索大3 小时前
【算法】递归的艺术:从本质思想到递归树,深入剖析算法的性能权衡
经验分享·笔记·算法·改行学it
王哈哈^_^3 小时前
【数据集+完整源码】水稻病害数据集,yolov8水稻病害检测数据集 6715 张,目标检测水稻识别算法实战训推教程
人工智能·算法·yolo·目标检测·计算机视觉·视觉检测·毕业设计
light_in_hand3 小时前
内存区域划分——垃圾回收
java·jvm·算法
小安同学iter4 小时前
SQL50+Hot100系列(11.7)
java·算法·leetcode·hot100·sql50