二叉搜索树中的搜索
题目:力扣题目链接
难度:简单
给定二叉搜索树(BST)的根节点 root 和一个整数值 val。
你需要在 BST 中找到节点值等于 val 的节点。 返回以该节点为根的子树。 如果节点不存在,则返回 null 。
**示例 **
输入:root = [4,2,7,1,3], val = 2
输出:[2,1,3]
思路
二叉搜索树是一个有序树:
若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值;
若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值;
它的左、右子树也分别为二叉搜索树。
定义二叉树结点
//二叉树节点的定义。
class TreeNode {
int val;
TreeNode left;
TreeNode right;
TreeNode(){}
TreeNode(int val){
this.val = val;
}
TreeNode(int val,TreeNode left,TreeNode right){
this.val = val;
this.left = left;
this.right = right;
}
}
递归代码
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);
}else{//去右子树里找
return searchBST(root.right,val);
}
}
}
迭代代码
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 root;
}
}