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

相关推荐
AI科技星7 分钟前
算子数学|独立完整学科章节(百条原创公式· ROOT传世定稿)
大数据·算法·机器学习·数学建模·数据挖掘·量子计算
0xDevNull9 分钟前
分布式事务实战指南:从理论到Seata落地
java·开发语言·后端
斯维赤14 分钟前
每天学习一个小算法:堆排序
学习·算法·排序算法
椰猫子15 分钟前
Spring Framework(Bean)
java·前端·spring
道清茗16 分钟前
【RH294知识点汇总】第 7 章 《 使用角色和 Ansible 内容集合简化 Playbook 》
java·前端·ansible
ncj39343790620 分钟前
Canvas 图形开发高频算法面试题
算法·canvas
MediaTea21 分钟前
AI 术语通俗词典:F1 值(分类)
人工智能·算法·机器学习·分类·数据挖掘
踩坑记录21 分钟前
leetcode hot100 300. 最长递增子序列 medium 动态规划
leetcode·动态规划
南境十里·墨染春水24 分钟前
linux学习进展 线程同步——条件变量
java·开发语言·学习
窥视未来32 分钟前
MySQL 性能调优完全指南:从硬件到 SQL,一篇吃透
java·数据库