代码随想录算法训练营Day20

力扣235.二叉搜索树的最近公共祖先 【medium】
力扣701.二叉搜索树的插入操作 【medium】
力扣450.删除二叉搜索树中的节点【medium】

一、力扣235.二叉搜索树的最近公共祖先【medium】

题目链接:力扣235.二叉搜索树的最近公共祖先

文档链接:代码随想录

1、思路

  • 要利用二叉搜索树有序的性质
  • 题目说了p、q都在树中,所以我们可以通过遍历往下缩小范围
  • 这边不用判断空节点,因为pq的存在性和树的有序性,所以这边不会递归到空节点
  • 时间复杂度: O ( n ) O(n) O(n)

2、代码

python 复制代码
class Solution:
    def lowestCommonAncestor(self, root: 'TreeNode', p: 'TreeNode', q: 'TreeNode') -> 'TreeNode':
        x = root.val
        if x < p.val and x < q.val:
            return self.lowestCommonAncestor(root.right, p, q)
        if x > p.val and x > q.val:
            return self.lowestCommonAncestor(root.left, p , q)
        return root

二、力扣701.二叉搜索树的插入操作【medium】

题目链接:力扣701.二叉搜索树的插入操作

文档链接:代码随想录

1、思路

  • 可以不改变树的结构,这样这道题就简单了
  • 通过比较
  • 时间复杂度: O ( n ) O(n) O(n)

2、代码

python 复制代码
class Solution:
    def insertIntoBST(self, root: Optional[TreeNode], val: int) -> Optional[TreeNode]:
        if not root:
            return TreeNode(val)
        if root.val > val:
            root.left = self.insertIntoBST(root.left , val)
        if root.val < val:
            root.right = self.insertIntoBST(root.right , val)
        return root

三、力扣450.删除二叉搜索树中的节点【medium】

题目链接:力扣450.删除二叉搜索树中的节点

文档链接:代码随想录

1、思路

  • 遍历中寻找key,并不全遍历
  • 删除节点的操作在终止条件
  • 好好理解终止条件的return和最后的return root,这个过程中它就删除了目标节点并且把目标节点的孩子接向了它的父亲
  • 时间复杂度: O ( n ) O(n) O(n)

2、代码

python 复制代码
class Solution:
    def deleteNode(self, root, key):
        if root is None:
            return root
        if root.val == key:
            if root.left is None and root.right is None:
                return None
            elif root.left is None:
                return root.right
            elif root.right is None:
                return root.left
            else:
                cur = root.right
                while cur.left is not None:
                    cur = cur.left
                cur.left = root.left
                return root.right
        if root.val > key:
            root.left = self.deleteNode(root.left, key)
        if root.val < key:
            root.right = self.deleteNode(root.right, key)
        return root

相关推荐
GG不是gg3 分钟前
位运算详解之异或运算的奇妙操作
算法
FF-Studio2 小时前
万物皆数:构建数字信号处理的数学基石
算法·数学建模·fpga开发·自动化·音视频·信号处理·dsp开发
叶子爱分享3 小时前
从事算法工作对算法刷题量的需求
算法
勇闯IT3 小时前
有多少小于当前数字的数字
java·数据结构·算法
liuqun03194 小时前
开心灿烂go开发面试题
算法·leetcode·golang
liulilittle4 小时前
通过高级处理器硬件指令集AES-NI实现AES-256-CFB算法并通过OPENSSL加密验证算法正确性。
linux·服务器·c++·算法·安全·加密·openssl
小皮侠4 小时前
【算法篇】逐步理解动态规划模型6(回文串问题)
java·开发语言·算法·动态规划
IT猿手4 小时前
动态多目标进化算法:基于迁移学习的动态多目标粒子群优化算法(TrMOPSO)求解IEEE CEC 2015,提供完整MATLAB代码
算法·matlab·迁移学习·动态多目标进化优化·动态多目标算法
এ᭄画画的北北4 小时前
力扣-279.完全平方数
数据结构·算法·leetcode
实习生小黄4 小时前
双三次贝塞尔曲面-canvas 实现4x4网格图片变化功能
前端·算法