【二叉搜索树】【递归】【迭代】Leetcode 700. 二叉搜索树中的搜索

【二叉搜索树】【递归】【迭代】Leetcode 700. 二叉搜索树中的搜索

    • 二叉搜索树
    • 解法1 递归法
    • 解法2 迭代法

---------------🎈🎈题目链接🎈🎈-------------------
在这里插入图片描述

二叉搜索树

二叉搜索树
二叉搜索树(Binary Search Tree,BST)是一种特殊的二叉树,具有以下性质:

有序性: 对于二叉搜索树中的每个节点,其左子树中的所有节点的值都小于该节点的值,而右子树中的所有节点的值都大于该节点的值。这意味着对于任何节点,其左子树中的值都小于该节点的值,右子树中的值都大于该节点的值。

唯一性: 二叉搜索树中不存在重复的节点。

搜索操作: 由于二叉搜索树的有序性,可以利用二分查找的思想进行快速的搜索。给定一个值,可以从根节点开始比较,根据比较结果决定是向左子树还是向右子树搜索,直到找到目标节点或者搜索到叶子节点为止。

插入操作: 插入操作也是根据节点值的大小关系进行的。从根节点开始,比较要插入的节点值与当前节点值的大小关系,如果小于当前节点值,则继续在左子树中插入;如果大于当前节点值,则继续在右子树中插入。直到找到合适的位置插入新节点。

删除操作: 删除操作相对复杂一些。如果要删除的节点是叶子节点,则可以直接删除;如果要删除的节点只有一个子节点,则将其子节点替换到被删除节点的位置;如果要删除的节点有两个子节点,则通常选择该节点的前驱节点或者后继节点来替换被删除节点,并递归地删除用于替换的节点。

二叉搜索树的这些性质使得其在搜索、插入和删除等操作上具有较高的效率。然而,如果树的结构不平衡(比如极端情况下,树退化成链表),则操作的时间复杂度可能会退化到O(n),而不再是平衡状态下的O(log n)。因此,在实际应用中,通常会考虑使用平衡二叉搜索树(如AVL树、红黑树等)来保持搜索性能的稳定。


解法1 递归法

时间复杂度:在最坏情况下,时间复杂度为 O(h),其中 h 是树的高度。在一个平衡的二叉搜索树中,树的高度近似为 log(n),其中 n 是树中节点的数量。但是在最坏情况下,树可能会退化成链表,高度为 n。因此,在最坏情况下,时间复杂度为 O(n),在平均情况下,为 O(log n)。

空间复杂度:递归调用的栈空间取决于树的高度,因此空间复杂度也是 O(h)。在最坏情况下,树可能会退化成链表,空间复杂度为 O(n),在平均情况下,为 O(log n)。


/**
 * Definition for a binary tree node.
 * public 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) {
        return helper(root,val);
    }
    public TreeNode helper(TreeNode root, int val){
        if(root == null) return null;
        if(root.val == val) return root;
        else if(root.val>val) {
            return searchBST(root.left,val);
        }
        else {
            return searchBST(root.right,val);
        } 
    }
}

解法2 迭代法

时间复杂度:在最坏情况下,时间复杂度为 O(h),其中 h 是树的高度。在一个平衡的二叉搜索树中,树的高度近似为 log(n),其中 n 是树中节点的数量。但是在最坏情况下,树可能会退化成链表,高度为 n。因此,在最坏情况下,时间复杂度为 O(n),在平均情况下,为 O(log n)。

空间复杂度:这种迭代方法不使用递归,只使用了常量级的额外空间,因此空间复杂度是 O(1)。

/**
 * Definition for a binary tree node.
 * public 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) {
        // 迭代法
        while(root != null){
            if(root.val > val){
                root = root.left;
            }
            else if(root.val < val){
                root = root.right;
            }
            else{
                return root;
            }
        }
        return null;
    }
}

http://www.niftyadmin.cn/n/5399432.html

相关文章

Redis性能攻略:Redis-benchmark工具与实用性能优化技巧

Redis作为一种高性能的内存数据库&#xff0c;广泛应用于各种业务场景。然而&#xff0c;随着业务规模的扩大和数据量的增长&#xff0c;Redis的性能问题逐渐凸显出来。为了提高Redis的性能&#xff0c;本文将深入探讨Redis性能优化方案&#xff0c;包括参数配置、数据结构、多…

Linux零基础快速入门

Linux的诞生 Linux创始人:林纳斯 托瓦兹 Linux 诞生于1991年&#xff0c;作者上大学期间 因为创始人在上大学期间经常需要浏览新闻和处理邮件&#xff0c;发现现有的操作系统不好用,于是他决心自己写一个保护模式下的操作系统&#xff0c;这就是Linux的原型&#xff0c;当时他…

二、TensorFlow结构分析(1)

目录 1、TF数据流图 1.1 TensorFlow结构分析 1.2 案例 2、图与TensorBoard 2.1 图结构 2.2 图相关操作 2.2.1 默认图 2.2.2 创建图 2.3 TensorBoard&#xff1a;可视化学习 2.3.1 数据序列化 - events文件 2.3.2 启动TensorBoard 2.4 OP 2.4.1 常见OP 2.4.2 指令…

单片机精进之路-8da转换

代码如下&#xff0c;随着给DA数据输入口的值由小到大变化&#xff0c;接DA输出口的LED由暗变亮。 //测试程序,下载后可观察到D13发光二极管由暗变亮再熄灭过程&#xff0c; #include<reg51.h> sbit wela P2^7; sbit dula P2^6; sbit dawr P3^6; sbit csda P3^2;unsi…

Day06:基础入门-抓包技术HTTPS协议APP小程序PC应用WEB转发联动

目录 HTTP/HTTPS协议抓包工具 Web浏览器抓包 APP应用抓包 WX小程序&PC应用抓包 思维导图 章节知识点&#xff1a; 应用架构&#xff1a;Web/APP/云应用/三方服务/负载均衡等 安全产品&#xff1a;CDN/WAF/IDS/IPS/蜜罐/防火墙/杀毒等 渗透命令&#xff1a;文件上传下载…

Unity 脚本-生命周期常用函数

在Unity中&#xff0c;万物皆是由组件构成的。 右键创建C&#xff03;脚本&#xff0c;拖动脚本到某物体的组件列表。 生命周期相关函数 using System.Collections; using System.Collections.Generic; using UnityEngine;// 必须要继承 MonoBehaviour 才是一个组件 // 类名…

C++之std::list

概念说明&#xff1a; List是由双链表实现的一个容器&#xff0c;每个节点存储一个元素&#xff0c;支持前后两种移动方向。List的内存随着添加的节点增加而增加。数据在内存上存储是不连续的。 1、构造与赋值。 list<int> nlist;//一个空的list list<int> nlist1…

C++敲桌子游戏

题目&#xff1a;敲桌子&#xff1a;从1开始数到100&#xff0c;如果数字的个位或者十位为7&#xff0c;或者数字是7的倍数&#xff0c;则显示"敲桌子"&#xff0c;否则显示数字本身 #include <iostream> /*敲桌子&#xff1a;从1开始数到100&#xff0c;如果…