[leetCode]700. 二叉搜尋樹中的搜尋
阿新 • • 發佈:2020-11-04
題目
連結: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;
}
}