算法-二叉树篇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;
    }
};
相关推荐
sheeta199814 小时前
LeetCode 每日一题笔记 日期:2025.11.24 题目:1018. 可被5整除的二进制前缀
笔记·算法·leetcode
gfdhy20 小时前
【c++】哈希算法深度解析:实现、核心作用与工业级应用
c语言·开发语言·c++·算法·密码学·哈希算法·哈希
百***060120 小时前
SpringMVC 请求参数接收
前端·javascript·算法
weixin_4577600020 小时前
Python 数据结构
数据结构·windows·python
一个不知名程序员www21 小时前
算法学习入门---vector(C++)
c++·算法
云飞云共享云桌面21 小时前
无需配置传统电脑——智能装备工厂10个SolidWorks共享一台工作站
运维·服务器·前端·网络·算法·电脑
明洞日记21 小时前
【数据结构手册002】动态数组vector - 连续内存的艺术与科学
开发语言·数据结构·c++
福尔摩斯张21 小时前
《C 语言指针从入门到精通:全面笔记 + 实战习题深度解析》(超详细)
linux·运维·服务器·c语言·开发语言·c++·算法
fashion 道格21 小时前
数据结构实战:深入理解队列的链式结构与实现
c语言·数据结构
橘颂TA21 小时前
【剑斩OFFER】算法的暴力美学——两整数之和
算法·leetcode·职场和发展