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


    题目链接:701. 二叉搜索树中的插入操作 - 力扣(LeetCode)

    题目描述:

    思路分析:由题可知,题目的要求是给我们一个二叉搜索树和一个 val,将这个 val 插入到二叉搜索树中,并且这个树仍然是二叉搜索树。题目中给了两个插入方式,第一种是将 val 插入到原来没有节点的位置;第二种是,将 val 替换掉已经存在的节点,然后重新调整树。通过观察发现第一种方法比第二种更加简单,所以我们接下来就根据第一种方法进行解答。

    插入 val 节点总共需要两步:

    1、寻找 val 节点插入的位置, 因为题目中的树是一个二叉搜索树,所以如果 root.val < val ,那么 val 应该插到右子树那边,我们只需要在右子树中再寻找合适的位置就可以了,如果 root.val > val, 那么从左子树中再寻找位置就可以。

    2、插入 val 节点,如何确定这个位置是我们要找的位置呢?由第一步可以知道,我们是从 root 节点开始向下找,所以当 root = null 时,说明我们已经找到了那个位置,这时候我们直接返回到上一个节点,如果此时 root.left == null && root.val > val,那么直接将 val 添加到 root.left 就可以,注意右边的情况和左边判断时一样,不能直接使用 else,如果直接使用 else,那么在回溯到中间的时候会将 val 重新添加到其他节点的右子树。

    代码示例:

    1. class Solution {
    2. public TreeNode insertIntoBST(TreeNode root, int val) {
    3. if(root == null) return new TreeNode(val);
    4. search(root,val);
    5. return root;
    6. }
    7. public void search(TreeNode root,int val) {
    8. if(root == null) return;
    9. if(root.val > val) {
    10. // 在左子树继续寻找
    11. search(root.left,val);
    12. }else {
    13. search(root.right,val);
    14. }
    15. if(root.left == null && root.val > val) {
    16. root.left = new TreeNode(val);
    17. }else if(root.right == null && root.val < val){
    18. root.right = new TreeNode(val);
    19. }
    20. }
    21. }

  • 相关阅读:
    长、短视频中场歇战
    基于dagger平台实现资源位的接口自动化
    仿everything的文件搜索工具项目详解:Part2
    基于FPGA的视频接口之千兆网口(三UDP搭建)
    excel巧用拼接函数CONCAT输出JSON、SQL字符串
    [CSS动效][按钮篇] 适用于 FlatUI 的扁平化按钮
    C/C++字符函数和字符串函数模拟实现与详解————长度不受限制的字符串函数
    移动端web开发最佳实践
    Linux进程替换
    mysql执行拼接的sql语句
  • 原文地址:https://blog.csdn.net/qq_61139806/article/details/133070096
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号