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

相关推荐
Tansmjs4 分钟前
实时数据可视化库
开发语言·c++·算法
WBluuue7 分钟前
Codeforces 1075 Div2(ABC1C2D1D2)
c++·算法
圣保罗的大教堂7 分钟前
leetcode 3650. 边反转的最小路径总成本 中等
leetcode
rabbit_pro18 分钟前
SpringBoot3使用PostGis+GeoTools整合MybatisPlus
java·spring
2401_8384725127 分钟前
C++模拟器开发实践
开发语言·c++·算法
望眼欲穿的程序猿36 分钟前
Ai8051U+DHT11温湿度!
java·开发语言
一只大马猴呀37 分钟前
IntelliJ IDEA 中启动项目不显示端口号
java·ide·intellij-idea
s1hiyu41 分钟前
实时控制系统验证
开发语言·c++·算法
daad7771 小时前
V4L2_mipi-csi
算法
2301_765703141 小时前
C++代码复杂度控制
开发语言·c++·算法