0%

Leetcode 230 二叉搜索树中第K小的元素

给定一个二叉搜索树的根节点 root ,和一个整数 k ,请你设计一个算法查找二叉搜索树中第 k 个最小元素(从 1 开始计数)。

我对于二叉搜索树的遍历还是不够熟练,这里采用了层序遍历的方法,将所有节点的值存入一个列表中,然后对列表进行排序,返回第k个元素即可。

实际上,对于一颗二叉搜索树,中序遍历的结果就是一个有序的列表,所以可以直接对二叉搜索树进行中序遍历,同时记录遍历的节点数,当遍历到第k个节点时,返回该节点的值即可。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
# 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:
queue, ans = [root], []
while queue:
tmp =[]
for node in queue:
if node.left: tmp.append(node.left)
if node.right: tmp.append(node.right)
ans.append(node.val)
queue = tmp
ans = sorted(ans)
return ans[k-1]