Java二叉搜索树知识点(含面试大厂题和源码)

二叉搜索树(Binary Search Tree,简称BST)是一种特殊的二叉树,它支持许多动态集合操作,如查找、插入、删除、最大值、最小值等。在二叉搜索树中,每个节点包含一个键(以及可能伴随的附加信息),并满足以下性质:

  1. 节点的左子树只包含键小于节点键的树。
  2. 节点的右子树只包含键大于节点键的树。
  3. 左右子树也必须分别为二叉搜索树。
  4. 没有键值相等的节点(假设所有的键都是唯一的)。

二叉搜索树的操作

  • 查找(Search):从根节点开始,与当前节点比较,若小于当前节点,则向左子树查找;若大于,则向右子树查找;相等则找到了目标节点。如果查找失败,则意味着树中不存在该键值。

  • 插入(Insert):插入操作类似于查找操作。从

根节点开始,根据插入的键值与当前节点的比较结果决定是向左子树走还是向右子树走,直到到达一个叶节点后的空位置,然后在那里创建新的节点。这样保证了树的二叉搜索属性不被破坏。

  • 删除(Delete):删除操作比较复杂,主要有三种情况:

    1. 删除的节点是叶节点:直接删除,不会影响其他节点。
    2. 删除的节点只有一个子节点:删除该节点,并用其子节点替代它的位置。
    3. 删除的节点有两个子节点:找到该节点的后继节点(右子树中的最小节点)或前驱节点(左子树中的最大节点),用它来替换被删除节点的位置,然后删除原后继节点或前驱节点的位置。
  • 最小值和最大值(Min/Max):在二叉搜索树中查找最小值和最大值相对简单。最小值总是在树的最左边的节点中找到,最大值总是在树的最右边的节点中找到。

  • 中序遍历(Inorder Traversal):中序遍历二叉搜索树可以得到一个键的有序序列。遍历的顺序是先遍历左子树,然后访问根节点,最后遍历右子树。

二叉搜索树的性能

二叉搜索树操作的性能依赖于树的高度。在最好的情况下(树是完全平衡的),操作的时间复杂度为O(log n),其中n是树中节点的数目。在最坏的情况下(树完全不平衡,形成了一个链),操作的时间复杂度退化为O(n)。

为了解决这个问题,出现了多种类型的平衡二叉搜索树,如AVL树、红黑树等,它们通过在树中进行旋转等操作来保持树的平衡,以此来保证操作的高效性。

掌握二叉搜索树的基本概念和操作对于理解更复杂的数据结构和算法至关重要。它不仅是许多高级数据结构的基础,而且也是面试中常见的考察点。在面试大厂时,考察二叉搜索树相关的问题是非常常见的。以下是三个涉及二叉搜索树的面试题,包括问题描述和Java实现代码。

题目1:验证二叉搜索树

问题描述:给定一个二叉树的根节点 root,判断其是否是一个有效的二叉搜索树。一个二叉搜索树具有如下特征:节点的左子树只包含小于当前节点的数,节点的右子树只包含大于当前节点的数,且左右子树也必须是二叉搜索树。

Java实现

public class TreeNode {int val;TreeNode left;TreeNode right;TreeNode(int x) { val = x; }
}public class Solution {private TreeNode prev = null;public boolean isValidBST(TreeNode root) {return inorder(root);}private boolean inorder(TreeNode node) {if (node == null) return true;if (!inorder(node.left)) return false;if (prev != null && node.val <= prev.val) return false;prev = node;return inorder(node.right);}
}

题目2:二叉搜索树中第K小的元素

问题描述:给定一个二叉搜索树,编写一个函数 kthSmallest 来查找其中第 k 小的元素。

Java实现

public class Solution {private int count = 0;private int result = 0;public int kthSmallest(TreeNoderoot, int k) {inorderTraversal(root, k);return result;}private void inorderTraversal(TreeNode node, int k) {if (node == null) return;inorderTraversal(node.left, k);count++;if (count == k) {result = node.val;return;}inorderTraversal(node.right, k);}
}

题目3:将有序数组转换为二叉搜索树

问题描述:给你一个整数数组 nums,其中元素已经按升序排列,请你将其转换为一棵高度平衡的二叉搜索树。高度平衡二叉树是指一个二叉树每个节点的左右两个子树的高度差的绝对值不超过 1。

Java实现

public class TreeNode {int val;TreeNode left;TreeNode right;TreeNode(int x) { val = x; }
}class Solution {public TreeNode sortedArrayToBST(int[] nums) {if (nums == null || nums.length == 0) return null;return constructBSTRecursive(nums, 0, nums.length - 1);}private TreeNode constructBSTRecursive(int[] nums, int left, int right) {if (left > right) return null;int mid = left + (right - left) / 2;TreeNode node = new TreeNode(nums[mid]);node.left = constructBSTRecursive(nums, left, mid - 1);node.right = constructBSTRecursive(nums, mid + 1, right);return node;}
}

这些题目不仅检验你对二叉搜索树概念的理解,还考察你解决问题的能力和代码实现的能力。在面试中能够熟练地解答出类似题目,通常会给面试官留下较好的印象。不过,记住理解题目背后的逻辑和原理是最重要的,代码只是实现思路的一种表达方式。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/763583.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java最后一块石头的重量 II(力扣Leetcod1049)

最后一块石头的重量 II 力扣原题 有一堆石头&#xff0c;用整数数组 stones 表示。其中 stones[i] 表示第 i 块石头的重量。 每一回合&#xff0c;从中选出任意两块石头&#xff0c;然后将它们一起粉碎。假设石头的重量分别为 x 和 y&#xff0c;且 x < y。那么粉碎的可能结…

数据分析面试题(11~20)

11、对数据分析的看法&#xff0c;你怎么理解数据分析师这个职业&#xff1f; ①职责是收集、处理和分析大量的数据&#xff0c;并从中提取出有用的信息。 ②工作范围包括数据清洗、数据建模、数据可视化等。 数据收集和清洗&#xff1a;收集各种来源的数据&#xff0c;并清洗…

Orbit 使用指南06 | 创建基础环境 | Isaac Sim | Omniverse

如是我闻&#xff1a; 环境将模拟的不同方面如场景、观测和行动空间、重置事件等汇集在一起&#xff0c;为各种应用创建一个连贯的接口。在Orbit中&#xff0c;环境是作为envs.BaseEnv和envs.RLTaskEnv类实现的。这两个类非常相似&#xff0c;但envs.RLTaskEnv对强化学习任务很…

打气泵方案——汽车轮胎打气泵方案

打气泵控制方案功能介绍&#xff1a; 主控芯片和压力传感器&#xff1a;用于感测轮胎内部的气压&#xff0c;并通过大气压原理驱动气泵工作。 电机控制&#xff1a;通常采用MOS管和外部充气开关&#xff0c;以确保气压值的准确性。 显示功能&#xff1a;LED或LCD显示屏&#xf…

Linux系统磁盘动态扩容

文章目录 背景磁盘扩容CentOS 7、Aliyun Linux&#xff1a; MBR分区无损切换为GPT分区 背景 随着云计算的发展&#xff0c; 云上资源使用愈加灵活。 在日常使用ECS中&#xff0c;时常会遇到有状态服务随着运行时间越来越长&#xff0c;导致数据日积月累越来越多&#xff0c; 磁…

LangChain模块介绍

LangChain模块介绍 Model I/O Prompts 提示词 Template 模板 复用Selector 提示词选择器 根据不同的条件选择不同的提示词 Language Models 语言模型 LLM 指代续写模型 Chat 对话形态的大语言模型 区分不同的语言模型 Output Parsers JSONStructured Data Connection ​ 构…

MATLAB 2023a:强化学习算法的实战演练与性能评估

在深度学习领域&#xff0c;MATLAB 2023版深度学习工具箱以其完整的工具链和高效的运行环境&#xff0c;为研究人员和开发者提供了前所未有的便利。这一工具箱不仅集成了建模、训练和部署的全部功能&#xff0c;更以其简洁易用的语法和强大的算法库&#xff0c;为深度学习任务的…

leetcode每日一题1969

目录 一.题目原型&#xff1a; 二思路解析&#xff1a; 三.代码实现: 一.题目原型&#xff1a; 二思路解析&#xff1a; 灵神的做法非常让人惊叹&#xff1a; 理解就是&#xff0c;如果一个数大于另一个数要交换的1的权重&#xff0c;那么他们的乘积就变小。 那么一个大的数…

关闭Elasticsearch built-in security features are not enabled

禁用Kibana安全提示&#xff08;Elasticsearch built-in security features are not enabled&#xff09; Kibana提示#! Elasticsearch built-in security features are not enabled. Without authentication, your cluster could be accessible to anyone. See https://www.e…

鸿蒙开发图形图像:【图形子系统】

图形子系统 图形子系统主要包括UI组件、布局、动画、字体、输入事件、窗口管理、渲染绘制等模块&#xff0c;构建基于轻量OS应用框架满足硬件资源较小的物联网设备或者构建基于标准OS的应用框架满足富设备的OpenHarmony系统应用开发。 1.1 轻量系统 简介 图形子系统主要包括…

Redis五种数据结构,以及所对应在大厂中的实战应用

Redis五种数据结构&#xff0c;以及所对应在大厂中的实战 String应用场景&#xff08;单值缓存、对象缓存、分布式锁、计数器、存储session集群共享、分布式全局序列号&#xff09; Hash应用场景对象缓存、电商购物车、购物车操作优点&#xff1a;1. 同类别归类存储 2. 消耗更小…

实至名归!苏州金龙旅行家荣获“高端旅游之星”殊荣

荣光熠熠&#xff0c;加冕时刻&#xff01;苏州金龙KLQ6127旅行家再度以出众实力&#xff0c;在高端用车领域璀璨夺目。 3月20日&#xff0c;见证中国品牌力量——2024&#xff08;第四届&#xff09;中国商用车品牌营销盛典在北京隆重举办。此次盛典旨在表彰卓越&#xff0c;…

DXP学习2- 绘制电气图【实验】

目录 一、实验目的 二、实验原理 1、创建一个新的项目文件。 2、新建原理图文件 3、设置原理图选项 4、放置元器件 5、其他电路元素的放置 6、对所有电路元素属性参数值的修改 三、实验设备 四、实验内容 1、绘制实验图2-1 元器件所在位置&#xff1a; 1&#xff0c;…

yank+mermaid+甘特图实例

因为notion对于mermaid支持很一般&#xff0c;尤其是甘特图&#xff0c;如果时间跨度大、节点多&#xff0c;字号会小到看不见&#xff0c;非常不方便。 同样的代码&#xff0c;在notion中如下图所示&#xff1a;&#xff08;下图是我的一份年度规划&#xff09; &#xff08;…

STM32之HAL开发——初识HAL库

HAL库介绍 自从ST公司推出HAL库来替代原有的标准库&#xff0c;HAL库开始慢慢的被广大STM32开发者所接受&#xff0c;现在已经在实际的项目开发中大量使用&#xff0c;HAL库使得项目的移植变得简单容易。 Drivers&#xff1a;文件夹下是官方的 CMSISI 库&#xff0c; HAL 库&am…

全网最详细的生产小工单介绍——生产看板介绍篇

生产小工单&#xff0c;你了解多少&#xff1f;生产小工单在生产管理中扮演着怎样的角色&#xff1f;生产小工单适用于哪些对象和业务流程&#xff1f;生产小工单又能为企业带来哪些显著优势&#xff1f;如何高效搭建生产看板模板&#xff0c;让生产小工单发挥最大价值&#xf…

详解rtklib中main函数如何配置文件

目录 Step1&#xff1a;如何给rtklib中的主函数 rnx2rtkp 传参 Step2&#xff1a;给配置选项结构体赋默认值 Step3&#xff1a;继续配置 Step4&#xff1a;寻找 main 函数参数中的 -k Step5&#xff1a;依次遍历参数 Step1&#xff1a;如何给rtklib中的主函数 rnx2rtkp 传参…

基于51单片机的智能窗帘设计

标题&#xff1a;基于51单片机的智能窗帘设计 摘要&#xff1a; 随着智能家居的兴起&#xff0c;智能窗帘作为其中的重要组成部分&#xff0c;受到了广泛的关注。本文设计了一种基于51单片机的智能窗帘系统&#xff0c;该系统能够根据环境光线强度和用户设定&#xff0c;自动调…

第十四届蓝桥杯JavaB组省赛真题 - 阶乘求和

/ 10^9考虑前九位&#xff0c;% 10^9保留后9位 解题思路: 求获取结果的后九位数字&#xff0c;需要对10^9取余&#xff0c;因为202320232023这个数字的阶乘太大&#xff0c;必须要减少计算量&#xff0c;因为当一个整数乘以10^9后对其取余&#xff0c;那么结果都为0。 所以我…

Linux系统------------MySQL事务

目录 一、MySQL事务的概念 二、事务的ACID特点 ●原子性 ●一致性 ●隔离性 ●持久性 事务之间的相互影响有以下几种&#xff1a; ①脏读 ②不可重复读 ③幻读 ④丢失更新 三、Mysql及事务隔离级别 3.1Mysql及事务隔离级别 &#xff08;1&#xff09;read…