• 【LeetCode】701.二叉搜索树中的插入操作


    题目

    给定二叉搜索树(BST)的根节点 root 和要插入树中的值 value ,将值插入二叉搜索树。 返回插入后二叉搜索树的根节点。 输入数据 保证 ,新值和原始二叉搜索树中的任意节点值都不同。
    注意,可能存在多种有效的插入方式,只要树在插入后仍保持为二叉搜索树即可。 你可以返回 任意有效的结果 。

    示例 1:
    在这里插入图片描述

    输入:root = [4,2,7,1,3], val = 5
    输出:[4,2,7,1,3,5]
    解释:另一个满足题目要求可以通过的树是:

    示例 2:

    输入:root = [40,20,60,10,30,50,70], val = 25
    输出:[40,20,60,10,30,50,70,null,null,25]

    示例 3:

    输入:root = [4,2,7,1,3,null,null,null,null,null,null], val = 5
    输出:[4,2,7,1,3,5]

    提示:

    树中的节点数将在 [0, 104]的范围内。
    -108 <= Node.val <= 108
    所有值 Node.val 是 独一无二 的。
    -108 <= val <= 108
    保证 val 在原始BST中不存在。

    题解

    /**
     * Definition for a binary tree node.
     * struct TreeNode {
     *     int val;
     *     TreeNode *left;
     *     TreeNode *right;
     *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
     *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
     *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
     * };
     */
    class Solution {
    public:
        TreeNode* insertIntoBST(TreeNode* root, int val) {
            if(root == nullptr)
                return new TreeNode(val);
    
            TreeNode* node = root;
            while(node)
            {
                if(val < node->val)
                {
                    if(node->left)
                        node = node->left;
                    else
                    {
                        node->left = new TreeNode(val);
                        break;
                    }
                }
                else
                {
                    if(node->right)
                        node = node->right;
                    else
                    {
                        node->right = new TreeNode(val);
                        break;
                    }
                }
            }
            return root;
        }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44

    递归

    class Solution {
    public:
        TreeNode* insertIntoBST(TreeNode* root, int val) {
            if(root == nullptr)
                return new TreeNode(val);
    
            if(val < root->val)
                root->left = insertIntoBST(root->left,val);
            else
                root->right = insertIntoBST(root->right,val);
            return root;
        }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
  • 相关阅读:
    Android高级编程之自定义ContentProvider
    mac 下安装PHP zip扩展
    时间序列分析|数据裁剪和滚动异常值检测
    Python采集某购物软件数据信息,轻松拿捏千元外包项目
    运维困局下确保系统稳定的可行性
    【网络通信 -- WebRTC】Open WebRTC Toolkit 环境搭建指南
    .NET混合开发解决方案12 网页JS调用C#方法访问WinForm或WPF窗体
    LinkedList(4):多线程LinkedList 不安全情况
    Java类是如何默认继承Object的?(转载)
    java80-GULqq界面
  • 原文地址:https://blog.csdn.net/qq_45972928/article/details/126136618