1. 程式人生 > 實用技巧 >[leetCode]700. 二叉搜尋樹中的搜尋

[leetCode]700. 二叉搜尋樹中的搜尋

題目

連結:https://leetcode-cn.com/problems/search-in-a-binary-search-tree

給定二叉搜尋樹(BST)的根節點和一個值。 你需要在BST中找到節點值等於給定值的節點。 返回以該節點為根的子樹。 如果節點不存在,則返回 NULL。

例如,

給定二叉搜尋樹:

        4
       / \
      2   7
     / \
    1   3

和值: 2
你應該返回如下子樹:

      2     
     / \   
    1   3
在上述示例中,如果要找的值是 5,但因為沒有節點值為 5,我們應該返回 NULL。

遞迴

class Solution {
    public TreeNode searchBST(TreeNode root, int val) {
        if (root == null || root.val == val) return root;
        if (root.val > val) return searchBST(root.left, val);
        if (root.val < val) return searchBST(root.right, val);
        return null;
    }
}

迭代

普通二叉樹在搜尋某個節點時需要回溯,但是由於二叉搜尋樹的有序性不使用棧就能找到某個節點,不需要回溯的過程,因為節點的有序性就幫我們確定了搜尋的方向。

class Solution {
    public TreeNode searchBST(TreeNode root, int val) {
        while (root != null) {
            if (root.val > val) root = root.left;
            else if (root.val < val) root = root.right;
            else return root;
        }
        return null;
    }
}