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

思路

在二叉搜索树中插入新节点。首先检查树是否为空,若空则直接创建新节点。否则通过遍历树结构,比较节点值大小决定向左或向右子树移动,直到找到合适的空位置插入新节点。时间复杂度为O(h),其中h是树的高度。该实现保持了二叉搜索树的性质,即左子树值小于父节点,右子树值大于父节点。

代码

cpp 复制代码
class Solution {
public:
    TreeNode* insertIntoBST(TreeNode* r, int b) {
        TreeNode* a=r;
        if(!r) {
            r=new TreeNode(b);
        }
        while(a) {
            if(a->val>b) {
                if(a->left) {
                    a=a->left;
                }
                else {
                    a->left=new TreeNode(b);
                    return r;
                }
            }
            else {
                if(a->right) {
                    a=a->right;
                }
                else {
                    a->right=new TreeNode(b);
                    return r;
                }
            }
        }
        return r;
    }
相关推荐
tankeven2 小时前
HJ100 等差数列
c++·算法
ADDDDDD_Trouvaille2 小时前
2026.2.22——OJ98-100题
c++·算法
tankeven2 小时前
HJ99 自守数
c++·算法
一只理智恩2 小时前
基于 CesiumJS + React + Go 实现三维无人机编队实时巡航可视化系统
前端·人工智能·算法·golang·无人机
菜鸡儿齐2 小时前
leetcode-分割回文串
算法·leetcode·职场和发展
重生之我是Java开发战士2 小时前
【优选算法】链表:两数相加,两两交换节点,重排链表,合并K个升序链表,K个一组反转链表
数据结构·算法·链表
菜鸡儿齐2 小时前
leetcode-组合总和
算法·leetcode·深度优先
滴滴答滴答答2 小时前
LeetCode Hot100 之 19 接雨水
算法·leetcode·职场和发展
网小鱼的学习笔记2 小时前
leetcode283移动零元素
java·开发语言·算法