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

相关推荐
啊我不会诶8 小时前
求LCA 倍增法
c++·算法·深度优先
CoderIsArt8 小时前
编译器构建中涉及的算法
数据库·算法
暮冬-  Gentle°8 小时前
编译器优化屏障使用
开发语言·c++·算法
云淡风轻~窗明几净8 小时前
关于TSP的海岸线猜想:SeaLine算法的逐层法(不同于逐点法)
数据结构·算法·动态规划·模拟退火算法
刀法如飞8 小时前
AI时代,重温10大经典排序算法
算法·排序算法·ai编程
m0_730115118 小时前
模板编程中的SFINAE技巧
开发语言·c++·算法
mldlds9 小时前
Spring Boot 实战:轻松实现文件上传与下载功能
java·数据库·spring boot
NAGNIP9 小时前
面试官:给我讲一下卷积吧!
算法·面试
xxjj998a9 小时前
Spring Boot 整合 Apollo 配置中心实战
java·spring boot·后端
2401_831824969 小时前
高性能计算集群部署
开发语言·c++·算法