算法-二叉树篇23-二叉搜索树中的插入操作

二叉搜索树中的插入操作

力扣题目链接

题目描述

给定二叉搜索树(BST)的根节点 root 和要插入树中的值 value ,将值插入二叉搜索树。 返回插入后二叉搜索树的根节点。 输入数据 保证 ,新值和原始二叉搜索树中的任意节点值都不同。

注意,可能存在多种有效的插入方式,只要树在插入后仍保持为二叉搜索树即可。 你可以返回 任意有效的结果 。

解题思路

我感觉这个方法有点不太合理(必须值和树没有重复的,而且只能插在叶子节点处,虽然插入一个没有什么大问题,但是如果插入元素过多可能会导致树深度较大)解决的方法应该是调整改树,但是目前没有想到合适的方法来解决。

查看了一些题解都没有涉及到这个问题,之后如果学习中遇到了,再回来补充一下。

题解就是比较节点直到寻找到合适的位置插入就行,没什么难度。

题解

复制代码
class Solution {
public:
    TreeNode* insertIntoBST(TreeNode* root, int val) {
        TreeNode* creat = new TreeNode(val);
        if(!root){
            return creat;
        }
        
        TreeNode* cur = root;
        while(cur != NULL){
            if(val > cur->val){
                if(cur->right){
                    cur = cur->right;
                }
                else{
                    cur->right = creat;
                    break;
                }
            }
            else if(val < cur->val){
                if(cur->left){
                    cur = cur->left;
                }
                else {
                    cur->left = creat;
                    break;
                }
            }
        }

        return root;
    }
};
相关推荐
sw12138915 分钟前
C++中的代理模式实战
开发语言·c++·算法
ballball~~1 小时前
ISP-CCM(Color Correction Matrix)
图像处理·数码相机·算法
Sunshine for you1 小时前
实时操作系统中的C++
开发语言·c++·算法
中科院提名者1 小时前
BPE 算法的硬核拆解——理解词表(Vocabulary)是如何从零训练出来的,以及字符串是如何被切碎的
算法
「QT(C++)开发工程师」2 小时前
C++11三大核心特性深度解析:类型特征、时间库与原子操作
java·c++·算法
乐分启航2 小时前
SliMamba:十余K参数量刷新SOTA!高光谱分类的“降维打击“来了
java·人工智能·深度学习·算法·机器学习·分类·数据挖掘
你真是饿了3 小时前
算法专题二:滑动窗口
算法
ccLianLian4 小时前
数论·约数
数据结构·算法
会编程的土豆4 小时前
【数据结构与算法】最短路径---Dijkstra 算法
数据结构·c++·算法
2401_879693874 小时前
C++中的观察者模式实战
开发语言·c++·算法