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

相关推荐
武子康1 分钟前
Java-183 OSS 上传实战:Java 原生与 Spring Boot 集成
java·开发语言·spring boot·分布式·spring·阿里云·oss
know__ledge2 分钟前
吴恩达机器学习2022 -- Course1 -- Week3(分类问题)
人工智能·算法·目标检测·机器学习·分类
ALex_zry6 分钟前
Rust语言基础分析与C++对比:系统编程的现代演进
java·c++·rust
星释7 分钟前
Rust 练习册 105:从零开始实现链表数据结构
数据结构·链表·rust
良木生香9 分钟前
【数据结构-初阶】详解算法复杂度:时间与空间复杂度
数据结构
会员果汁12 分钟前
优先级队列-C语言
c语言·数据结构·算法
你不是我我13 分钟前
【Java 开发日记】阻塞队列有哪些?拒绝策略有哪些?
java·开发语言
却话巴山夜雨时i14 分钟前
347. 前 K 个高频元素【中等】
数据结构·算法·leetcode
蘑菇小白15 分钟前
数据结构--栈
数据结构·算法·
(●—●)橘子……15 分钟前
力扣344.反转字符串 练习理解
python·学习·算法·leetcode·职场和发展