二叉搜索树--新增节点-力扣 701 题

例题细节二叉搜索树的基础操作-CSDN博客也讲过了(put),下面给出递归实现

java 复制代码
public TreeNode insertIntoBST(TreeNode node, int val) {
    //找到空位了
    if(node == null) {
        return new TreeNode(val);
    }
    if(val < node.val) {
        //一直找到有null的位置时就新增节点
        node.left = insertIntoBST(node.left, val);//将新创建好的新节点与父节点建立联系
    } else if(node.val < val) {
        node.right = insertIntoBST(node.right, val);
    }
    return node;
}
//这个递归的缺点:多出一些不必要的赋值动作,来时的所有节点又要在重新建立父子关系  如果要用非递归实现就不会有这种情况
  • 注意事项与上题相同,不再赘述

  • 题目提示输入的 val 一定与树中节点不同,因此只需考虑新增 情况,不会出现更新情况

相关推荐
disgare几秒前
SpringBoot 请求调用时关于高可用机制选型和落地
java·spring boot·后端
旖-旎7 分钟前
深搜(二叉树剪枝)(3)
数据结构·c++·算法·力扣·剪枝·递归
CodeMartain7 分钟前
@SpringBootApplication 到底是什么呢?
java·spring boot·intellij-idea
流年如夢9 分钟前
结构体:定义、使用与内存布局
c语言·开发语言·数据结构·c++·算法
星秀日11 分钟前
大学生开发社区项目-CLXHXH-登录功能
java
兩尛17 分钟前
struct,union,Class,bitfield各自的作用和区别
java·开发语言
算.子18 分钟前
【Spring AI 实战】八、完整 RAG 问答实战:检索 + 重排序 + 生成全链路
java·人工智能·spring
wuminyu25 分钟前
专家视角看 Java 字节码与Class 文件格式
java·linux·c语言·jvm·c++
Gauss松鼠会29 分钟前
【openGauss】openGauss 磁盘引擎之 ustore
java·服务器·开发语言·前端·数据库·经验分享·gaussdb
lee_curry37 分钟前
线程中断,等待,唤醒与ThreadLocal
java·线程·juc·threadlocal·中断