代码随想录之二叉搜索树的插入操作

本题在力扣701

本体思路学习于代码随想录

JAVA版本

思路:本题的思想较为简单,直接找到适合插入的结点来进行插入即可

解法一:

递归法:

复制代码
class Solution {
    public TreeNode insertIntoBST(TreeNode root, int val) {
        if(root ==null) {
            return new TreeNode(val);
        }
        if(root.val < val){
            root.right = insertIntoBST(root.right,val);
        } else {
            root.left = insertIntoBST(root.left,val);
        }
        return root;
    }
}

解法二:

迭代法:

迭代法的思想就是找到最适合插入的结点,在最适合插入的结点来进行插入操作。

复制代码
class Solution {
    public TreeNode insertIntoBST(TreeNode root, int val) {
         if (root == null) return new TreeNode(val);

        TreeNode newRoot = root;
        TreeNode pre = root;
        while(root != null) {
            pre = root;
            if (root.val > val) {
                root = root.left;
            } else if (root.val < val) {
                root = root.right;
            } 
        }
        if (pre.val > val) {
            pre.left = new TreeNode(val);
        } else {
            pre.right = new TreeNode(val);
        }

        return newRoot;
    }
}
相关推荐
小月球~6 小时前
天梯赛 · 并查集
数据结构·算法
仍然.7 小时前
算法题目---模拟
java·javascript·算法
6Hzlia8 小时前
【Hot 100 刷题计划】 LeetCode 118. 杨辉三角 | C++ 动态规划题解
c++·leetcode·动态规划
潇冉沐晴9 小时前
DP——背包DP
算法·背包dp
GIOTTO情9 小时前
2026 世界互联网大会亚太峰会|AI 时代媒介投放的技术实战与算法优化
人工智能·算法
逆境不可逃9 小时前
LeetCode 热题 100 之 543. 二叉树的直径 102. 二叉树的层序遍历 108. 将有序数组转换为二叉搜索树 98. 验证二叉搜索树
算法·leetcode·职场和发展
计算机安禾10 小时前
【数据结构与算法】第19篇:树与二叉树的基础概念
c语言·开发语言·数据结构·c++·算法·visual studio code·visual studio
副露のmagic10 小时前
哈希章节 leetcode 思路&实现
算法·leetcode·哈希算法
副露のmagic10 小时前
字符串章节 leetcode 思路&实现
windows·python·leetcode
csuzhucong10 小时前
puzzle(1037)黑白、黑白棋局
算法