力扣230.二叉搜索树中第k小的元素、199.二叉树的右视图、114.二叉树展开为链表

230.二叉搜索树中第k小的元素

思路:

1、二叉搜索树的性质是其中序遍历为递增序列。利用该性质即可将题意转化为中序遍历的第k个元素

2、中序遍历按照左中右的顺序进行,中间的处理需要对计数进行减1的操作,并验证其是否为0,若为0,则记录下此刻的数值并返回

注意:

Python 中,局部变量的作用域仅限于定义它们的函数内部。在 kthSmallest 方法中定义的变量 k 是局部变量,它在 kthSmallest 方法的作用域内有效。嵌套函数 dfs 无法直接访问外部方法的局部变量 k,因为 dfs 有自己的作用域。

为了在嵌套函数 dfs 中访问和修改 k 的值,可以将 k 定义为类的成员变量。类的成员变量可以通过 self 关键字在类的任何方法中访问和修改。在 kthSmallest 方法中,将 k 赋值给 self.k,这样 dfs 函数就可以通过 self.k 来访问和修改这个值。

代码:

python 复制代码
class Solution:
    def kthSmallest(self, root: Optional[TreeNode], k: int) -> int:
        def dfs(root):
            if root is None:
                return
            dfs(root.left)
            self.k -= 1
            if self.k == 0:
                self.res = root.val
                return
            dfs(root.right)

        self.k = k
        dfs(root)
        return self.res

参考:

https://leetcode.cn/problems/kth-smallest-element-in-a-bst/solutions/2361685/230-er-cha-sou-suo-shu-zhong-di-k-xiao-d-n3he

199.二叉树的右视图

思路:

看到题目所说的右视图很容易联想到需要一层一层进行遍历来获取每层的最右侧元素,故采用层序遍历。基本步骤与层序遍历一致,只是增加了一个列表来记录并返回。

代码:

python 复制代码
class Solution:
    def rightSideView(self, root: Optional[TreeNode]) -> List[int]:
        if not root:
            return []
        
        queue = collections.deque([root])  # 用列表记录每一层元素
        right_view = []

        while queue:
            size = len(queue)

            for i in range(size):  # 遍历每一层
                cur = queue.popleft()

                if i == size - 1:  # 验证是否为最右侧元素
                    right_view.append(cur.val)

                if cur.left:
                    queue.append(cur.left)
                if cur.right:
                    queue.append(cur.right)

        return right_view

114.二叉树展开为链表

思路:

按照前序遍历中左右的方式进行更新,创建一个前置节点用来修改左右子树连接;但由于需要把左子树置到右节点处,所以需要额外变量对右子树进行存储,否则会丢失。

代码:

python 复制代码
class Solution:
    pre = None # 用来记录前一节点并对root进行更新
    def flatten(self, root: Optional[TreeNode]) -> None:
        """
        Do not return anything, modify root in-place instead.
        """
        # 前序遍历中左右,递归返回条件
        if not root:
            return None
        # 非空时指定左右节点
        if self.pre:
            self.pre.left = None
            self.pre.right = root
        self.pre = root  # 更新
        right = root.right  # 保留右子树,否则再上一个if语句中修改了右子树会导致其丢失
        self.flatten(root.left)
        self.flatten(right)

复杂度分析:

  • 时间复杂度:O(n),其中 n 是二叉树的节点个数。
  • 空间复杂度:O(n)。递归需要 O(n) 的栈空间。
相关推荐
forEverPlume5 小时前
SQL如何统计分组内不重复值的数量_COUNT与DISTINCT结合应用
jvm·数据库·python
shehuiyuelaiyuehao5 小时前
算法14,滑动窗口,找到字符串中所有字母异位词
算法
凯瑟琳.奥古斯特5 小时前
图论核心考点精讲
开发语言·数据结构·算法·排序算法·哈希算法
WolfGang0073215 小时前
代码随想录算法训练营 Day49 | 图论 part07
算法·图论
啦啦啦_99995 小时前
案例之 逻辑回归_癌症预测
算法·机器学习·逻辑回归
chaofan9805 小时前
突破大模型落地瓶颈:Claude 4.7 与 GPT-5.5 长上下文工程实测
数据库·人工智能·python·gpt·自动化·php·api
StockTV5 小时前
韩国股票实时数据 KOSPI(主板)和 KOSDAQ(创业板)的实时行情、K 线及指数数据
java·开发语言·算法·php
2501_901200535 小时前
PHP源码部署需要多大硬盘空间_PHP项目存储空间估算方法【方法】
jvm·数据库·python
byte轻骑兵5 小时前
【LE Audio】BASS精讲[5]: 状态特征解析,广播接收状态实时可视全流程
人工智能·算法·音视频·语音识别·le audio·低功耗音频
豆瓣鸡5 小时前
Agent实战练习
java·python·学习