LeetCode 701.二叉搜索树中的插入操作

ops/2025/2/28 10:50:14/

题目描述

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

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

示例 1:

输入:root = [4,2,7,1,3], val = 5
输出:[4,2,7,1,3,5]
解释:另一个满足题目要求可以通过的树是:

示例 2:

输入:root = [40,20,60,10,30,50,70], val = 25
输出:[40,20,60,10,30,50,70,null,null,25]

示例 3:

输入:root = [4,2,7,1,3,null,null,null,null,null,null], val = 5
输出:[4,2,7,1,3,5]

提示:

  • 树中的节点数将在 [0, 10^4]的范围内。
  • -10^8 <= Node.val <= 10^8
  • 所有值 Node.val 是 独一无二 的。
  • -10^8 <= val <= 10^8
  • 保证 val 在原始BST中不存在。

思路

本题可以不考虑题目中提示所说的改变树的结构的插入方式。

递归法

递归三部曲:

  1. 确定递归函数的参数和返回值。参数就是根节点指针,以及要插入元素。本题可以有返回值也可以没有,但递归函数如果没有返回值的话,实现是比较麻烦的,有返回值的话,可以利用返回值完成新加入的节点与其父节点的赋值操作。
  2. 确定终止条件。终止条件就是找到遍历的节点为null的时候,就是要插入节点的位置了,并把插入的节点返回。
  3. 确定单层递归的逻辑。根据插入元素的数值,决定递归方向,下一层将加入节点返回,本层用root->left或者root->right将其接住。

代码

C++版:

递归法

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode() : val(0), left(nullptr), right(nullptr) {}*     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}*     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/
class Solution {
public:// 递归法TreeNode* insertIntoBST(TreeNode* root, int val) {// 终止条件就是要插入节点的时候if (root == NULL) {TreeNode* node = new TreeNode(val);return node;}if (root->val > val) root->left = insertIntoBST(root->left, val); // 插入新节点if (root->val < val) root->right = insertIntoBST(root->right, val); // 插入新节点return root;}
};

迭代法

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode() : val(0), left(nullptr), right(nullptr) {}*     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}*     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/
class Solution {
public:// 迭代法TreeNode* insertIntoBST(TreeNode* root, int val) {if (root == NULL) {TreeNode* node = new TreeNode(val);return node;}TreeNode* cur = root;TreeNode* pre = root; while (cur != NULL) {pre = cur; // 需要记录上一个节点,否则无法赋值新节点if (cur->val > val) cur = cur->left;else cur = cur->right;}TreeNode* node = new TreeNode(val);if (val < pre->val) pre->left = node;// 用pre节点进行赋值else pre->right = node;return root;}
};

Python版:

递归法

python"># Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:# 递归法def insertIntoBST(self, root: Optional[TreeNode], val: int) -> Optional[TreeNode]:if root is None:node = TreeNode(val)return nodeif root.val > val:root.left = self.insertIntoBST(root.left, val)if root.val < val:root.right = self.insertIntoBST(root.right, val)return root

需要注意的地方

1.在二叉搜索树中插入任何一个节点都可以在叶子结点中找到对应的位置。

2.本题使用了一个技巧:通过递归返回值来加入新节点。


http://www.ppmy.cn/ops/161937.html

相关文章

Idea 中 Project Structure简介

在 IntelliJ IDEA 中&#xff0c;Project Structure&#xff08;项目结构&#xff09;对话框是一个非常重要的配置界面&#xff0c;它允许你对项目的各个方面进行详细的设置和管理。下面将详细介绍 Project Structure 中各个主要部分的功能和用途。 1. Project&#xff08;项…

RabbitMQ高级特性----生产者确认机制

题记&#xff1a;在Java微服务开发中&#xff0c;对于一个功能需要调用另一个服务下的功能才能实现的情况&#xff0c;我们通常会使用异步调用取代同步调用&#xff0c;进而实现增强业务的可拓展性和实现故障隔离以及流量削峰填谷的目的。而消息队列就是异步调用的解决方案之一…

基于大数据的音乐网站数据分析与可视化推荐系统

【大数据】基于大数据的音乐网站数据分析与可视化推荐系统&#xff08;完整系统源码开发笔记详细部署教程&#xff09;✅ 目录 一、项目简介二、项目界面展示三、项目视频展示 一、项目简介 本选题旨在设计并实现一款基于大数据技术的音乐网站数据分析与可视化推荐系统&#x…

linux在vim中查找和替换

在Linux中使用Vim编辑器查找文本的方法非常直观和强大。Vim是一个高度可配置的文本编辑器&#xff0c;支持多种查找和替换的命令。下面是一些基本的查找命令&#xff1a; 1. 向前查找 要向前查找文本&#xff0c;可以使用以下命令&#xff1a; /text_to_find 例如&#xff0c…

[数字排列]

数字排列 真题目录: 点击去查看 E 卷 100分题型 题目描述 小明负责公司年会,想出一个趣味游戏: 屏幕给出 1 ~ 9 中任意 4 个不重复的数字,大家以最快时间给出这几个数字可拼成的数字从小到大排列位于第 N 位置的数字,其中 N 为给出数字中最大的(如果不到这么多数字则给…

3D技术在文博行业的革新应用有哪些?

在当今社会&#xff0c;看展览已成为国人精神生活的重要组成部分&#xff0c;而“云游博物馆”作为一种新兴趋势&#xff0c;正以前所未有的速度席卷文化领域。众多博物馆紧跟时代步伐&#xff0c;利用多样化的手段&#xff0c;让文化传播更加贴近大众生活。其中&#xff0c;3D…

Linux——高级IO(select后续poll,epoll)

目录 一、poll函数 1.函数原型 2.参数说明 3.struct pollfd 结构体 4.返回值 5.使用步骤 6.与 select 的对比 7.适用场景 8.缺点 9.总结 二、epoll函数 1.核心思想 2.核心函数 1. epoll_create - 创建 epoll 实例 2. epoll_ctl - 管理 epoll 事件表 3. epoll_w…

【 树 】

【树 】 目录1. 二叉搜索树&#xff08;BST&#xff09;的退化知识点示例 2. 平衡树的定义3. AVL 树知识点不平衡产生的原因旋转操作 4. AVL 树代码设计树节点旋转操作插入节点操作删除节点操作测试代码 红黑树的定义代码设计节点类设计左旋和右旋操作 插入操作删除操作黑侄情形…