【LeetCode 刷题】二叉树(6)-二叉搜索树的属性

此博客为《代码随想录》二叉树章节的学习笔记,主要内容为二叉搜索树的属性相关的题目解析。

文章目录

700.二叉搜索树中的搜索

题目链接

python 复制代码
class Solution:
    def searchBST(self, root: Optional[TreeNode], val: int) -> Optional[TreeNode]:
        if not root or root.val == val:
            return root
        if root.val < val:
            return self.searchBST(root.right, val)
        else:
            return self.searchBST(root.left, val)
  • 二叉树上的二分查找

98.验证二叉搜索树

题目链接

python 复制代码
class Solution:
    pre = -inf
    def isValidBST(self, root: Optional[TreeNode]) -> bool:
        if not root:
            return True
        left = self.isValidBST(root.left)
        if not left or root.val <= self.pre:
            return False
        self.pre = root.val
        return self.isValidBST(root.right)
  • 二叉搜索树的中序遍历结果是递增序列,因此在中序遍历 过程中判断 pre.valcur.val 的大小关系
  • 上述写法中,由于只返回是否合法的布尔值,因此可以不用额外创建递归函数,将 pre 定义为类的成员变量
  • pre 初始化为负无穷,可以避免特判

530.二叉搜索树的最小绝对差

题目链接

python 复制代码
class Solution:
    def getMinimumDifference(self, root: Optional[TreeNode]) -> int:
        pre, res = -inf, inf

        def traversal(node: Optional[TreeNode]) -> None:
            if not node:
                return
            traversal(node.left)
            nonlocal pre, res
            res = min(res, node.val - pre)
            pre = node.val
            traversal(node.right)
        
        traversal(root)
        return res
  • 由于需要完整遍历整个二叉搜索树后,才可知最小绝对差,因此需要创建额外的递归函数,但函数返回值为空,仅用于遍历

501.二叉搜索树中的众数

题目链接

python 复制代码
class Solution:
    def findMode(self, root: Optional[TreeNode]) -> List[int]:
        pre, cur, cur_max, res = -inf, -inf, -inf, []

        def traversal(node: Optional[TreeNode]) -> None:
            if not node:
                return
            traversal(node.left)
            nonlocal pre, cur, cur_max, res
            # 更新 cur
            cur = cur + 1 if node.val == pre else 1
            # 更新 cur_max 和 res
            if cur > cur_max:
                cur_max = cur
                res = [node.val]
            elif cur == cur_max:
                res.append(node.val)
            # 更新 pre
            pre = node.val
            traversal(node.right)
        
        traversal(root)
        return res
  • 主要思路与上题类似,在中序遍历的同时统计特定的量
  • 需要注意此题的众数可能不止一个,需要同时返回,因此当频次相同时,都放入 res 列表中作为答案

538.把二叉搜索树转换为累加树

题目链接

python 复制代码
class Solution:
    def convertBST(self, root: Optional[TreeNode]) -> Optional[TreeNode]:
        pre_sum = 0

        def traversal(node: Optional[TreeNode]) -> None:
            if not node:
                return
            traversal(node.right)
            nonlocal pre_sum
            pre_sum += node.val
            node.val = pre_sum
            traversal(node.left)
        
        traversal(root)
        return root
  • 以"右、中、左"的顺序遍历,同时累加 pre_sum
相关推荐
robin_suli13 分钟前
穷举vs暴搜vs深搜vs回溯vs剪枝系列一>黄金矿工
算法·剪枝·深度优先遍历·回溯
tanactor18 分钟前
回溯算法中关于剪枝的一些应用
算法·剪枝
大厂在职_Xbg18 分钟前
Dagger2进阶学习
前端·python·学习
大象机器人44 分钟前
使用外骨骼灵活远程控制协作机器人案例
开发语言·python·机器人·机械臂
土了个豆子的1 小时前
冒泡排序的原理及优化
开发语言·数据结构·算法·visualstudio·c#·排序算法
deephub2 小时前
DeepSeek技术报告解析:为什么DeepSeek-R1 可以用低成本训练出高效的模型
人工智能·python·深度学习·机器学习·deepseek
西农小陈2 小时前
Python-基于PyQt5,Pillow,pathilb,imageio,moviepy,sys的GIF(动图)制作工具
python·小程序·pycharm·pyqt·pillow
AI视觉网奇2 小时前
llama_index
人工智能·python
数据小小爬虫2 小时前
Jsoup库具体怎么用?
java·爬虫·python
notfindjob2 小时前
deepseek API 调用-python
python·聊天机器人·deepseek