二叉搜索树的特点:
左子树的所有节点值 都比 root.val小
右子树的所有节点值 都比 root.val大
可利用此特性写code:
递归法
# 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 searchBST(self, root: Optional[TreeNode], val: int) -> Optional[TreeNode]:
if root == None or root.val == val:
return root
if root.val > val: return self.searchBST(root.left, val)
if root.val < val: return self.searchBST(root.right, val)
迭代法:
# 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 searchBST(self, root: Optional[TreeNode], val: int) -> Optional[TreeNode]:
while root != None:
if root.val > val: root = root.left
elif root.val < val: root = root.right
else: return root

本文介绍了二叉搜索树的基本特点及其应用,详细讲解了如何使用递归和迭代两种方法在二叉搜索树中查找特定值的节点。
1224

被折叠的 条评论
为什么被折叠?



