【leetcode】230: 二叉搜索树中第K小的元素

 这个题目利用二叉搜索树的性质,一下子就简单得令人发指了,第k小的元素,正好就是对二叉搜索树进行中序遍历时的第k个元素,因此我们直接使用中序遍历,时间复杂度O(n),即可得到答案,代码如下:

# 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 kthSmallest(self, root: Optional[TreeNode], k: int) -> int:
        ls=[]
        def DFS(root,ls):
            if root==None:
                return 
            DFS(root.left,ls)
            ls.append(root.val)
            DFS(root.right,ls)
        
        DFS(root,ls)
        return ls[k-1]

得解!

原文地址:https://www.cnblogs.com/geeksongs/p/15408620.html