其他分享
首页 > 其他分享> > 701. 二叉搜索树中的插入操作(中等)

701. 二叉搜索树中的插入操作(中等)

作者:互联网

题目链接:701. 二叉搜索树中的插入操作

在这里插入图片描述
思路:拿val与根结点值比大小,看从左走还是往右走
这是添加一个叶子结点的方法;原来的结点值不发生改变
一开始思路就想错了,我还以为原二叉树的结点值还有发生交换。

class Solution {
public:
    TreeNode* insertIntoBST(TreeNode* root, int val) {
        if (root == nullptr) {            //空树
            return new TreeNode(val);
        }

        TreeNode* pos = root;
        while (pos != nullptr) {
            if (val < pos->val) {   //val<当前结点  往左走
                if (pos->left == nullptr) {
                    pos->left = new TreeNode(val);
                    break;
                }
                else {
                    pos = pos->left;
                }
            }
            else {    //往右走
                if (pos->right == nullptr) {
                    pos->right = new TreeNode(val);
                    break;
                }
                else {
                    pos = pos->right;
                }
            }
        }

        return root;
    }
};

标签:结点,TreeNode,val,root,nullptr,pos,701,二叉,树中
来源: https://blog.csdn.net/qq_39236499/article/details/121277260