码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Leetcode 701. 二叉搜索树中的插入操作


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

    题目

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

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

    思路

    • 确定递归的参数和返回值:参数就是根节点指针,以及要插入的元素,递归函数有返回值,可以利用返回值完成新加入的节点与其父节点的赋值操作
    • 确定终止条件:当前便利的节点是NULL,则该节点就是要插入节点的位置,并把插入的节点返回
    • 确定单层递归的逻辑:搜索树是有方向的,可以根据插入元素的数值决定递归的方向

    代码

    /**
     * Definition for a binary tree node.
     * struct TreeNode {
     *     int val;
     *     TreeNode *left;
     *     TreeNode *right;
     *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
     *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
     *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
     * };
     */
    class Solution {
    public:
        TreeNode* insertIntoBST(TreeNode* root, int val) {
            if(root == NULL)
            {
                // 递归出口
                TreeNode* node = new TreeNode(val);// 新建一个节点
                return node;
            }
            if(root->val > val)
            {
                root->left = insertIntoBST(root->left,val);
            }
            if(root->val < val)
            {
                root->right = insertIntoBST(root->right,val);
            }
            return root;
        }
    };
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
  • 相关阅读:
    DFS 模板:843. n-皇后问题
    马来酰亚胺/碳碳双键表面/硫硅烷基团/金属硫蛋白修饰二氧化硅微球的性能与制备
    .NET 6 轻量级 WebApi 框架 FastEndpoints 入门
    【C++多线程那些事儿】多线程的执行顺序如你预期吗?
    Redis两种持久化方案RDB 和 AOF
    mysql只copy数据库文件而不copy系统表文件到另一个数据库,新库可以正常使用该库和表吗?
    2022下半年软考报名入口!
    图形学-向量基础与应用
    在T3开发板上实现SylixOS最小系统(二)
    为什么电商创业者2022年都在做抖音小店无货源?揭开抖店无货源玩法
  • 原文地址:https://blog.csdn.net/qq_44653420/article/details/126249634
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号