二叉搜索树--新增节点-力扣 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 一定与树中节点不同,因此只需考虑新增 情况,不会出现更新情况

相关推荐
rchmin4 分钟前
Spring Boot自动装配原理解析
java·spring boot·后端
MobotStone6 分钟前
一夜蒸发1000亿美元后,Google用什么夺回AI王座
算法
Wang2012201310 分钟前
RNN和LSTM对比
人工智能·算法·架构
程序员小假11 分钟前
我们来说一下 synchronized 与 ReentrantLock 的区别
java·后端
益达32113 分钟前
【避坑指南】Maven依赖冲突怎么解决?用mvn dependency:tree一眼看清
java
xueyongfu14 分钟前
从Diffusion到VLA pi0(π0)
人工智能·算法·stable diffusion
永远睡不够的入24 分钟前
快排(非递归)和归并的实现
数据结构·算法·深度优先
cheems952724 分钟前
二叉树深搜算法练习(一)
数据结构·算法
sin_hielo26 分钟前
leetcode 3074
数据结构·算法·leetcode
Yzzz-F33 分钟前
算法竞赛进阶指南 动态规划 背包
算法·动态规划