• 每日一题~二叉搜索树中的插入操作


    题目链接: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. }

  • 相关阅读:
    【ZYNQ】zynq启动模式及程序固化
    解决flutter不识别yaml里面配置的git项目
    【python数据建模】Scipy库
    Web SSH 的原理与在 ASP.NET Core SignalR 中的实现
    【操作系统】进程间的通信——信号量
    day12学习总结
    vue项目 element UI input框扫码枪扫描过快 出现数据丢失问题(已解决二)
    IIs部署发布vue项目测试环境
    01 `Linux`基础
    基于JavaGUI的大学生竞赛管理系统
  • 原文地址:https://blog.csdn.net/qq_61139806/article/details/133070096