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

相关推荐
夏鹏今天学习了吗20 小时前
【LeetCode热题100(82/100)】单词拆分
算法·leetcode·职场和发展
曹轲恒20 小时前
Java中断
java·开发语言
xxxmine20 小时前
Java并发wait(timeout)
java
冰冰菜的扣jio20 小时前
Redis缓存问题——一致性问题、事务、持久化
java·spring·mybatis
施棠海20 小时前
监听与回调的三个demo
java·开发语言
mit6.82420 小时前
mysql exe
算法
2501_9011478321 小时前
动态规划在整除子集问题中的应用与高性能实现分析
算法·职场和发展·动态规划
中草药z21 小时前
【嵌入模型】概念、应用与两大 AI 开源社区(Hugging Face / 魔塔)
人工智能·算法·机器学习·数据集·向量·嵌入模型
毕设源码-钟学长21 小时前
【开题答辩全过程】以 家政服务平台为例,包含答辩的问题和答案
java
踩坑记录21 小时前
leetcode hot100 189.轮转数组 medium
leetcode