代码随想录算法训练营第十八天|Day18二叉树

235. 二叉搜索树的最近公共祖先

题目链接/文章讲解:https://programmercarl.com/0235.%E4%BA%8C%E5%8F%89%E6%90%9C%E7%B4%A2%E6%A0%91%E7%9A%84%E6%9C%80%E8%BF%91%E5%85%AC%E5%85%B1%E7%A5%96%E5%85%88.html

视频讲解:https://www.bilibili.com/video/BV1Zt4y1F7ww

思路

objectivec 复制代码
struct TreeNode* lowestCommonAncestor(struct TreeNode* root, struct TreeNode* p, struct TreeNode* q) {
    while (root) {
        if (root->val > p->val && root->val > q->val) {
            root = root->left; 
        } 
        else if (root->val < p->val && root->val < q->val) {
            root = root->right; 
        } 
        else {
            return root; 
        }
    }
    return NULL; 
}

学习反思

在函数中使用了迭代的方式进行查找,先判断当前节点的值与目标节点的值的大小关系,然后根据不同的情况移动到左子树或右子树。如果当前节点的值位于目标节点的值之间,则说明当前节点就是最近公共祖先。时间复杂度为O(n)。

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

题目链接/文章讲解:https://programmercarl.com/0701.%E4%BA%8C%E5%8F%89%E6%90%9C%E7%B4%A2%E6%A0%91%E4%B8%AD%E7%9A%84%E6%8F%92%E5%85%A5%E6%93%8D%E4%BD%9C.html

视频讲解:https://www.bilibili.com/video/BV1Et4y1c78Y

思路

objectivec 复制代码
struct TreeNode* insertIntoBST(struct TreeNode* root, int val) {
    struct TreeNode* newNode = (struct TreeNode*)malloc(sizeof(struct TreeNode));
    newNode->val = val;
    newNode->left = NULL;
    newNode->right = NULL;
    if (root == NULL) {
        return newNode;
    }
    struct TreeNode* current = root;
    struct TreeNode* parent = NULL;
    while (current != NULL) {
        parent = current; 
        if (val < current->val) {
            current = current->left;
        } else {
            current = current->right; 
        }
    }
    if (val < parent->val) {
        parent->left = newNode; 
    } else {
        parent->right = newNode; 
    }
    return root; 
}

学习反思

首先,创建一个新的节点,并将要插入的值赋给新节点的val属性。然后,判断树是否为空,如果为空,则直接返回新节点作为树的根节点。接下来,使用两个指针current和parent进行遍历和记录。初始化current为根节点,parent为NULL。在while循环中,遍历树,将parent指向当前节点,并根据要插入的值val和当前节点的值的大小关系,将current指向左子树或右子树。此时,current指向NULL,parent指向要插入位置的父节点。根据值的大小关系,将新节点插入到合适的位置,即parent的左子树或右子树。最后,返回树的根节点。时间复杂度为O(logn)到O(n)。

450.删除二叉搜索树中的节点

题目链接/文章讲解:https://programmercarl.com/0450.%E5%88%A0%E9%99%A4%E4%BA%8C%E5%8F%89%E6%90%9C%E7%B4%A2%E6%A0%91%E4%B8%AD%E7%9A%84%E8%8A%82%E7%82%B9.html

视频讲解:https://www.bilibili.com/video/BV1tP41177us

思路

objectivec 复制代码
struct TreeNode* deleteNode(struct TreeNode* root, int key) {
    if (root == NULL) {
        return NULL;
    }
    if (key < root->val) {
        root->left = deleteNode(root->left, key);
    } else if (key > root->val) {
        root->right = deleteNode(root->right, key);
    } else {
        if (root->left == NULL) {
            struct TreeNode* temp = root->right;
            free(root);
            return temp;
        } else if (root->right == NULL) {
            struct TreeNode* temp = root->left;
            free(root);
            return temp;
        } else {
            struct TreeNode* minNode = root->right;
            while (minNode->left != NULL) {
                minNode = minNode->left;
            }
            root->val = minNode->val;
            root->right = deleteNode(root->right, minNode->val);
        }
    }
    return root; 
}

学习反思

首先,判断根节点是否为空,如果为空,则直接返回null。接下来,根据要删除的值和当前节点的值的大小关系,递归地向左子树或右子树查找要删除的节点。

如果找到了要删除的节点,有以下几种情况:

  1. 如果要删除的节点没有左子树,直接返回右子树作为替代。
  2. 如果要删除的节点没有右子树,直接返回左子树作为替代。
  3. 如果要删除的节点有两个子节点,需要找到右子树中的最小节点,将其值替代当前节点的值,然后删除右子树中的最小节点。

最后,返回根节点。时间复杂度为O(logn)到O(n)。

总结

二叉树理解更深了,加油!!!

相关推荐
jolimark4 分钟前
C语言函数的构成、定义、使用方法及程序控制权转移介绍
c语言·函数调用·函数定义·参数传递·程序控制权
ths5125 分钟前
测试开发python中正则表达式使用总结(二)
开发语言·python·算法
不爱吃炸鸡柳9 分钟前
5道经典贪心算法题详解:从入门到进阶
开发语言·数据结构·c++·算法·贪心算法
枫叶林FYL15 分钟前
【自然语言处理 NLP】8.3 长文本推理评估与针在大海堆任务
人工智能·算法
智者知已应修善业18 分钟前
【51单片机1,左边4个LED灯先闪烁2次后,右边4个LED灯再闪烁2次:2,接着所用灯一起闪烁3次,接着重复步骤1,如此循环。】2023-5-19
c++·经验分享·笔记·算法·51单片机
米啦啦.18 分钟前
红黑树,,
数据结构·红黑树
xiaoye-duck24 分钟前
《算法题讲解指南:优选算法-队列+宽搜》--70.N叉树的层序遍历,71.二叉树的锯齿形层序遍历,72.二叉树的最大宽度,73.在每个树行中找最大值
数据结构·c++·算法·队列
汀、人工智能26 分钟前
[特殊字符] 第98课:数据流中位数
数据结构·算法·数据库架构··数据流·数据流中位数
Eloudy29 分钟前
不同特征值的特征向量互相正交的矩阵
人工智能·算法·机器学习