二叉树——17.二叉搜索树中的插入操作

2024-08-22 00:44

本文主要是介绍二叉树——17.二叉搜索树中的插入操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

力扣题目链接

给定二叉搜索树(BST)的根节点和要插入树中的值,将值插入二叉搜索树。 返回插入后二叉搜索树的根节点。 输入数据保证,新值和原始二叉搜索树中的任意节点值都不同。

注意,可能存在多种有效的插入方式,只要树在插入后仍保持为二叉搜索树即可。 你可以返回任意有效的结果。

解题思路

1. 理解二叉搜索树(BST)的性质

首先,需要理解二叉搜索树的基本性质:

  • 对于每个节点,左子树中所有节点的值都小于该节点的值。
  • 右子树中所有节点的值都大于该节点的值。
  • 因此,插入一个新值时,需要遵循这个规则,找到适合的位置。

2. 递归遍历寻找插入位置

为了找到新节点的插入位置,采用递归遍历树的方式:

  • 从根节点开始,比较当前节点的值与要插入的值。
    • 如果插入值小于当前节点的值,则进入左子树继续寻找。
    • 如果插入值大于当前节点的值,则进入右子树继续寻找。
  • 当找到一个空的子节点(即当前节点的子节点为 None)时,说明这是合适的插入位置。

3. 插入新节点

在递归遍历过程中,保持对当前节点的父节点的引用(parent)。当找到合适的插入位置时,根据插入值与父节点的比较结果,将新节点插入为父节点的左子节点或右子节点。

4. 处理特殊情况

在树为空的情况下,直接将新节点作为根节点返回。

5. 总体解题思路总结

  • 利用递归来遍历树,直到找到合适的插入位置。
  • 通过保持对父节点的引用,确保新节点可以正确地插入到树中。
  • 特殊情况下,直接处理空树并返回新的根节点。

这个思路的核心是利用二叉搜索树的性质和递归的思想,以保证插入操作符合 BST 的规则。

完整代码如下:

class Solution:def __init__(self):self.parent = Nonedef traversal(self, cur, val):if cur is None:node = TreeNode(val)if val > self.parent.val:self.parent.right = nodeelse:self.parent.left = nodereturnself.parent = curif cur.val > val:self.traversal(cur.left, val)if cur.val < val:self.traversal(cur.right, val)def insertIntoBST(self, root, val):self.parent = TreeNode(0)if root is None:return TreeNode(val)self.traversal(root, val)return root
def traversal(self, cur, val):if cur is None:node = TreeNode(val)if val > self.parent.val:self.parent.right = nodeelse:self.parent.left = nodereturnself.parent = curif cur.val > val:self.traversal(cur.left, val)if cur.val < val:self.traversal(cur.right, val)
  • 基准条件判断:

    • 如果 curNone,说明我们已经找到适合插入的位置。此时:
      • 创建一个新的 TreeNode,其值为 val
      • 根据 valself.parent.val 的比较结果,将新节点插入为 self.parent 的左子节点或右子节点。
      • 然后返回结束递归。
  • 递归遍历:

    • 在未找到插入位置时,继续沿着树遍历:
      • 当前节点的值 (cur.val) 大于 val 时,递归遍历当前节点的左子树。
      • 当前节点的值 (cur.val) 小于 val 时,递归遍历当前节点的右子树。
    • 在递归前更新 self.parent 为当前节点 cur,以便跟踪新节点的父节点。
def insertIntoBST(self, root, val):self.parent = TreeNode(0)if root is None:return TreeNode(val)self.traversal(root, val)return root
  • 初始化父节点:

    • 在执行插入操作前,将 self.parent 初始化为一个新的节点(值为0)。这个初始化操作主要为了处理边界情况,确保在整个插入过程中 parent 有合理的值。
  • 特殊情况处理:

    • 如果树为空(rootNone),直接返回一个新的节点作为根节点。
  • 调用 traversal 方法:

    • 否则,调用 traversal 方法,从根节点开始遍历,找到适合插入的位置并插入新节点。
  • 返回根节点:

    • 最后,返回操作后的树的根节点。

这篇关于二叉树——17.二叉搜索树中的插入操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1094759

相关文章

Go异常处理、泛型和文件操作实例代码

《Go异常处理、泛型和文件操作实例代码》Go语言的异常处理机制与传统的面向对象语言(如Java、C#)所使用的try-catch结构有所不同,它采用了自己独特的设计理念和方法,:本文主要介绍Go异... 目录一:异常处理常见的异常处理向上抛中断程序恢复程序二:泛型泛型函数泛型结构体泛型切片泛型 map三:文

Java使用Spire.Doc for Java实现Word自动化插入图片

《Java使用Spire.DocforJava实现Word自动化插入图片》在日常工作中,Word文档是不可或缺的工具,而图片作为信息传达的重要载体,其在文档中的插入与布局显得尤为关键,下面我们就来... 目录1. Spire.Doc for Java库介绍与安装2. 使用特定的环绕方式插入图片3. 在指定位

MySQL基本表查询操作汇总之单表查询+多表操作大全

《MySQL基本表查询操作汇总之单表查询+多表操作大全》本文全面介绍了MySQL单表查询与多表操作的关键技术,包括基本语法、高级查询、表别名使用、多表连接及子查询等,并提供了丰富的实例,感兴趣的朋友跟... 目录一、单表查询整合(一)通用模版展示(二)举例说明(三)注意事项(四)Mapper简单举例简单查询

Nginx概念、架构、配置与虚拟主机实战操作指南

《Nginx概念、架构、配置与虚拟主机实战操作指南》Nginx是一个高性能的HTTP服务器、反向代理服务器、负载均衡器和IMAP/POP3/SMTP代理服务器,它支持高并发连接,资源占用低,功能全面且... 目录Nginx 深度解析:概念、架构、配置与虚拟主机实战一、Nginx 的概念二、Nginx 的特点

C#实现插入与删除Word文档目录的完整指南

《C#实现插入与删除Word文档目录的完整指南》在日常的办公自动化或文档处理场景中,Word文档的目录扮演着至关重要的角色,本文将深入探讨如何利用强大的第三方库Spire.Docfor.NET,在C#... 目录Spire.Doc for .NET 库:Word 文档处理利器自动化生成:C# 插入 Word

MySQL 数据库进阶之SQL 数据操作与子查询操作大全

《MySQL数据库进阶之SQL数据操作与子查询操作大全》本文详细介绍了SQL中的子查询、数据添加(INSERT)、数据修改(UPDATE)和数据删除(DELETE、TRUNCATE、DROP)操作... 目录一、子查询:嵌套在查询中的查询1.1 子查询的基本语法1.2 子查询的实战示例二、数据添加:INSE

使用Python在PDF中绘制多种图形的操作示例

《使用Python在PDF中绘制多种图形的操作示例》在进行PDF自动化处理时,人们往往首先想到的是文本生成、图片嵌入或表格绘制等常规需求,然而在许多实际业务场景中,能够在PDF中灵活绘制图形同样至关重... 目录1. 环境准备2. 创建 PDF 文档与页面3. 在 PDF 中绘制不同类型的图形python

Java 操作 MinIO详细步骤

《Java操作MinIO详细步骤》本文详细介绍了如何使用Java操作MinIO,涵盖了从环境准备、核心API详解到实战场景的全过程,文章从基础的桶和对象操作开始,到大文件分片上传、预签名URL生成... 目录Java 操作 MinIO 全指南:从 API 详解到实战场景引言:为什么选择 MinIO?一、环境

MySQL 批量插入的原理和实战方法(快速提升大数据导入效率)

《MySQL批量插入的原理和实战方法(快速提升大数据导入效率)》在日常开发中,我们经常需要将大量数据批量插入到MySQL数据库中,本文将介绍批量插入的原理、实现方法,并结合Python和PyMySQ... 目录一、批量插入的优势二、mysql 表的创建示例三、python 实现批量插入1. 安装 PyMyS

Java轻松实现在Excel中插入、提取或删除文本框

《Java轻松实现在Excel中插入、提取或删除文本框》在日常的Java开发中,我们经常需要与Excel文件打交道,当涉及到Excel中的文本框时,许多开发者可能会感到棘手,下面我们就来看看如何使用J... 目录Java操作Excel文本框的实战指南1. 插入Excel文本框2. 提取Excel文本框内容3