美文网首页
二叉树 Leetcode 700 二叉搜索树中的搜索

二叉树 Leetcode 700 二叉搜索树中的搜索

作者: 禾木清清 | 来源:发表于2019-07-14 11:31 被阅读0次

    题目

    给定二叉搜索树(BST)的根节点和一个值。 你需要在BST中找到节点值等于给定值的节点。 返回以该节点为根的子树。 如果节点不存在,则返回 NULL。

    例如,

    给定二叉搜索树:

        4
       / \
      2   7
     / \
    1   3
    

    和值: 2
    你应该返回如下子树:

      2     
     / \   
    1   3
    

    在上述示例中,如果要找的值是 5,但因为没有节点值为 5,我们应该返回 NULL。

    在真实的面试中遇到过这道题?

    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/search-in-a-binary-search-tree
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    解题思路

    • 比较跟节点
    • 根据大小去左右子树
    • 返回根节点或者空

    代码

    # Definition for a binary tree node.
    # class TreeNode(object):
    #     def __init__(self, x):
    #         self.val = x
    #         self.left = None
    #         self.right = None
    
    class Solution(object):
        def searchBST(self, root, val):
            """
            :type root: TreeNode
            :type val: int
            :rtype: TreeNode
            """
            if not root:
                return None
            
            
            if root.val == val:
                return root
            elif root.val > val:
                return self.searchBST(root.left, val)
            else:
                return self.searchBST(root.right, val)
            return None
                    
    

    相关文章

      网友评论

          本文标题:二叉树 Leetcode 700 二叉搜索树中的搜索

          本文链接:https://www.haomeiwen.com/subject/lisbkctx.html