news 2026/6/23 20:52:30

LC.701 | 二叉搜索树中的插入操作 | 树 | 迭代模拟

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LC.701 | 二叉搜索树中的插入操作 | 树 | 迭代模拟

输入:
二叉搜索树的根节点root和一个待插入的整数val

要求:
val插入到二叉搜索树中,并保证插入后整棵树仍然满足 BST 的性质(左 < 根 < 右)。
题目保证新值和原始树中任意节点值都不同。

输出:
插入节点后的二叉搜索树的根节点。


思路:

在二叉搜索树中插入新节点,其实就是**“一次失败的查找”**。我们要找这个值应该在的位置,直到走到死胡同(空指针),那个位置就是它该待的地方。

本题解采用了迭代(循环)法,相比递归不仅逻辑直观,而且空间复杂度更优。

  1. 特判空树
    如果根节点为空,直接用新值创建一个节点并返回,它就是新的根。

  2. 寻找插入位置(模拟)
    使用while循环遍历树,利用 BST 性质(val大往右走,val小往左走)。

    • 关键技巧 - “向前看一步”
      在决定向左还是向右移动之前,先检查那边的路是不是断的(即子节点是否为null)。
      • 如果是null,说明找到了!直接new一个节点接上去,任务完成,返回根节点。
      • 如果不是null,则移动指针root继续向下寻找。

复杂度:

  • 时间复杂度:O(H)
    • 树的高度。我们需要从根遍历到叶子节点。
  • 空间复杂度:O(1)
    • 使用了迭代法,不需要递归栈,仅使用了常数个辅助变量。

classSolution{public:TreeNode*insertIntoBST(TreeNode*root,intval){if(!root){TreeNode*ans=newTreeNode(val);returnans;}TreeNode*ans=root;while(root){if(root->val<val){if(!root->right){TreeNode*tmp=newTreeNode(val);root->right=tmp;returnans;}else{root=root->right;}}else{if(!root->left){TreeNode*tmp=newTreeNode(val);root->left=tmp;returnans;}else{root=root->left;}}}returnans;}};
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/22 21:24:10

解锁优质创意素材:这四个专业平台值得收藏

在这个视觉驱动的时代&#xff0c;找到合适的正版素材已成为内容创作者的核心技能之一。无论是制作短视频、设计宣传物料&#xff0c;还是完成商业项目&#xff0c;优质的素材资源不仅能提升作品的专业度&#xff0c;更能有效规避版权风险。以下为您梳理四个风格各异但同样可靠…

作者头像 李华
网站建设 2026/6/23 11:47:18

毕设分享 深度学习遮挡下的人脸识别(源码+论文)

文章目录 0 前言1 项目运行效果2 设计概要4 最后 0 前言 &#x1f525;这两年开始毕业设计和毕业答辩的要求和难度不断提升&#xff0c;传统的毕设题目缺少创新和亮点&#xff0c;往往达不到毕业答辩的要求&#xff0c;这两年不断有学弟学妹告诉学长自己做的项目系统达不到老师…

作者头像 李华
网站建设 2026/6/23 17:30:55

Python UV搭配Miniconda:下一代包管理体验

Python UV 搭配 Miniconda&#xff1a;下一代包管理体验 在现代 AI 与数据科学项目中&#xff0c;一个常见的痛点是&#xff1a;明明本地跑得好好的代码&#xff0c;换到服务器或同事机器上就报错。追溯原因&#xff0c;往往是 numpy 版本不一致、CUDA 驱动缺失、或者某个依赖包…

作者头像 李华
网站建设 2026/6/23 0:07:14

实验室装修,怎样做更省心?

实验室装修&#xff0c;怎样做更省心&#xff1f;前言实验室装修是一项复杂且专业性极强的工程&#xff0c;涉及多个方面的考量。如何在保证质量和功能的前提下&#xff0c;让整个过程更加省心呢&#xff1f;本文将为您提供一些实用的建议。行业现状与痛点分析实验室装修的复杂…

作者头像 李华
网站建设 2026/6/23 1:03:06

Redis多数据源配置指南

Spring Boot Redis 多数据源配置指南 基于 Spring Boot 3.x + Lettuce 连接池,支持单机版和集群版 目录 1. Maven 依赖 2. 单机版多数据源配置 3. 集群版多数据源配置 4. 使用方式 5. 常见问题 1. Maven 依赖 <!-- Spring Data Redis -->

作者头像 李华