题解 | #插入二叉搜索树#

插入二叉搜索树

https://www.nowcoder.com/practice/4900db9ddfbd43a7a9841c6a408bacf2

简单题:val和当前结点比较,如果大于当前结点则往右走,小于则往左走,走到空的地方即是val的位置。
class Solution {
  public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param root TreeNode类
     * @param val int整型
     * @return TreeNode类
     */
    TreeNode* insertToBST(TreeNode* rootint val) {
        // write code here
        if (root == NULL) {
            root = new TreeNode(val);
            return root;
        }
        TreeNode* tmp = root;
        while (1) {
            if (val > tmp->val) {
                if (tmp->right == NULL) {
                    tmp->right = new TreeNode(val);
                    break;
                }
                tmp = tmp->right;

            } else {
                if (tmp->left == NULL) {
                    tmp->left = new TreeNode(val);
                    break;
                }
                tmp = tmp->left;
            }
        }
        return root;
    }
};
全部评论

相关推荐

点赞 收藏 评论
分享
牛客网
牛客企业服务