Leetcode700.二叉搜索树中搜索具体值

二叉搜索树的定义:

一颗空树或者具有以下性质的二叉树:

  1. 若任意节点的左子树不空,则左子树上所有节点的值均小于它的根节点的值;
  2. 若任意节点的右子树不空,则右子树上所有节点的值均大于它的根节点的值;
  3. 任意节点的左、右子树也分别为二叉查找树;

二叉搜索树是平衡树吗?

二叉搜索树不一定是平衡树。

二叉搜索树的搜索时间复杂度是O(log n),关于时间复杂度,可以参考:平衡二叉搜索树查找的时间复杂度为什么是O(log n)?

根据二叉搜索树的定义,如果目标值比节点值大,则搜索右子树,如果目标值比节点值小,则搜索左子树。

核心还是递归。

java 复制代码
class Solution {
    public TreeNode searchBST(TreeNode root, int val) {
        if (root == null) {
            return null;
        }
        if (val == root.val) {
            return root;
        }
        /**
         * 例如:
         * 搜索3,3<4成立,则搜索2
         * 搜索6,6<4不成立 ,则搜索7
         */
        return searchBST(val < root.val ? root.left : root.right, val);
    }
}
相关推荐
峥无3 天前
《二叉搜索树:动态数据管理的利器,平衡树的基石》
开发语言·c++·二叉搜索树
伟大的车尔尼16 天前
双指针题目:两数之和 IV - 输入二叉搜索树
二叉树··二叉搜索树·双指针
MSTcheng.24 天前
【C++】如何快速实现一棵支持key或key-value的二叉搜索树?关键技巧一文掌握!
开发语言·c++·算法·二叉搜索树
Fcy6481 个月前
二叉搜索树(C++实现)
开发语言·数据结构·c++·二叉搜索树
獭.獭.1 个月前
C++ -- 二叉搜索树
数据结构·c++·算法·二叉搜索树
月夜的风吹雨2 个月前
【C++二叉搜索树】:从原理到实战的深度解析
开发语言·c++·二叉搜索树
_OP_CHEN2 个月前
C++进阶:(三)深度解析二叉搜索树原理及实现
开发语言·数据结构·c++·二叉树·二叉搜索树·键值对
大数据张老师3 个月前
数据结构——二叉搜索树
数据结构·算法·二叉搜索树·查找·关键路径
2401_841495643 个月前
【数据结构】红黑树的基本操作
java·数据结构·c++·python·算法·红黑树·二叉搜索树
闪电麦坤955 个月前
数据结构:从前序遍历序列重建一棵二叉搜索树 (Generating from Preorder)
数据结构··二叉搜索树