• 【Day-36慢就是快】代码随想录-二叉树-二叉搜索树中的插入操作


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

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

    思路

    可以不用考虑题目中提示所说的改变树的结构的插入方式。

    只需要按照二叉搜索树的规则去遍历,然后遇到空节点插入节点就可以了。

    递归

    1. 确定递归参数和返回值

    参数就是传入根节点和插入节点的数值,添加当前节点的返回值可以实现新加入节点与其父节点的赋值绑定操作。

    2. 终止条件

    遍历的节点为空时,就是找到了插入节点的位置,并把插入的节点返回。

    1. if (root == NULL) {
    2. TreeNode* node = new TreeNode(val);
    3. return node;
    4. }

    3. 单层递归的逻辑

    搜索树是有方向的,根据插入元素的数值决定递归的方向。

    1. if (root->val > val) root->left = insertIntoBST(root->left, val);
    2. if (root->val < val) root->right = insertIntoBST(root->right, val);
    3. return root;

    这里用root->left接收返回值,同时也实现了当插入新节点后,与其父节点绑定的过程。

    整体代码:

    1. class Solution {
    2. public:
    3. TreeNode* insertIntoBST(TreeNode* root, int val) {
    4. if (root == NULL) {
    5. TreeNode* node = new TreeNode(val);
    6. return node;
    7. }
    8. if (root->val > val) root->left = insertIntoBST(root->left, val);
    9. if (root->val < val) root->right = insertIntoBST(root->right, val);
    10. return root;
    11. }
    12. };

    迭代法

    1. class Solution {
    2. public:
    3. TreeNode* insertIntoBST(TreeNode* root, int val) {
    4. if(root == NULL){
    5. TreeNode* node = new TreeNode(val);
    6. return node;
    7. }
    8. TreeNode* cur = root;
    9. TreeNode* parent = root;//记录上一个节点,否则无法赋值新节点
    10. while(cur != NULL){
    11. parent = cur;
    12. if(cur->val > val) cur = cur->left;
    13. else cur = cur->right;
    14. }
    15. TreeNode* node = new TreeNode(val);
    16. if(val < parent->val) parent->left = node; //绑定父节点
    17. else parent->right = node;
    18. return root;
    19. }
    20. };

  • 相关阅读:
    【AI视野·今日Sound 声学论文速览 第二十五期】Fri, 13 Oct 2023
    CSS3提高: CSS3 动画
    ARM +FPGA GPIB IP核实现
    【自然语言处理(NLP)】基于LSTM的命名实体识别(进阶)
    根据多个乱序经纬度计算多边形顶点顺序并绘制到指定地图上
    GZ038 物联网应用开发赛题第1套
    四、分类算法 - 朴素贝叶斯算法
    [Kotlin Tutorials 22] 协程中的异常处理
    Vuex环境搭建
    图神经网络通用框架 —— MPNN消息传递神经网络
  • 原文地址:https://blog.csdn.net/boru1588/article/details/132873975