← 返回题库
初级

二叉搜索树的第k大节点

未完成
初级参考 完整示例代码供参考,建议自己理解后重新输入
class TreeNode:
    def __init__(self, val=0, left=None, right=None):
        self.val = val
        self.left = left
        self.right = right

def solve():
    def kthLargest(root, k):
        result = []
        def reverseInorder(node):
            if not node or len(result) >= k:
                return
            reverseInorder(node.right)
            result.append(node.val)
            reverseInorder(node.left)
        reverseInorder(root)
        return result[k-1]
    root = TreeNode(3, TreeNode(1, None, TreeNode(2)), TreeNode(4))
    print(kthLargest(root, 1))

示例

输入
solve()
期望输出
4
Python 代码 🔒 登录后使用
🔒

登录后即可练习

注册免费账号,在浏览器中直接运行 Python 代码