【二叉树】二叉搜索树中的插入操作

0x00 题目

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

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


0x01 思路

因为是二叉搜索树
对于任意节点 root 而言
左子树上所有节点的值均小于 root.val
右子树上所有节点的值均大于 root.val
且它们都是二叉搜索树

根据 valroot.val 的大小关系
可以确定要将 val 插入到哪个子树中

子树为空则插入新节点


0x02 解法

语言:Swift

树节点:TreeNode

public class TreeNode {
    public var val: Int
    public var left: TreeNode?
    public var right: TreeNode?
    public init() { self.val = 0; self.left = nil; self.right = nil; }
    public init(_ val: Int) { self.val = val; self.left = nil; self.right = nil; }
    public init(_ val: Int, _ left: TreeNode?, _ right: TreeNode?) {
        self.val = val
        self.left = left
        self.right = right
    }
}

解法:

func insertIntoBST(_ root: TreeNode?, _ val: Int) -> TreeNode? {
    if root == nil { return TreeNode(val) }
    
    var node = root
    while node != nil {
        // 小于节点值
        if val < node!.val {
            if node!.left == nil {
                node!.left = TreeNode(val)
                break
            }else{
                node = node!.left
            }
        }
        // 大于节点值
        else{
            if node!.right == nil {
                node!.right = TreeNode(val)
                break
            }else{
                node = node!.right
            }
        }
    }
    
    return root
}

0x03 我的作品

欢迎体验我的作品之一:小五笔
五笔学习好帮手 👍🏻
App Store 搜索即可~


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

豪冷啊

你的鼓励是对我的认可!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值