当前位置:   article > 正文

代码随想录算法训练营第二十三天| LeetCode669. 修剪二叉搜索树、LeetCode108. 将有序数组转换为二叉搜索树、LeetCode538. 把二叉搜索树转换为累加树

代码随想录算法训练营第二十三天| LeetCode669. 修剪二叉搜索树、LeetCode108. 将有序数组转换为二叉搜索树、LeetCode538. 把二叉搜索树转换为累加树

一、LeetCode669. 修剪二叉搜索树

        1:题目描述(669. 修剪二叉搜索树

        给你二叉搜索树的根节点 root ,同时给定最小边界low 和最大边界 high。通过修剪二叉搜索树,使得所有节点的值在[low, high]中。修剪树 不应该 改变保留在树中的元素的相对结构 (即,如果没有被移除,原有的父代子代关系都应当保留)。 可以证明,存在 唯一的答案 。

        所以结果应当返回修剪好的二叉搜索树的新的根节点。注意,根节点可能会根据给定的边界发生改变。

        2:解题思路

        自己最开始的写法:

  1. # Definition for a binary tree node.
  2. # class TreeNode:
  3. # def __init__(self, val=0, left=None, right=None):
  4. # self.val = val
  5. # self.left = left
  6. # self.right = right
  7. class Solution:
  8. def trimBST(self, root: Optional[TreeNode], low: int, high: int) -> Optional[TreeNode]:
  9. def deleteNode(cur):
  10. if cur == None:
  11. # 当前节点为空,直接返回None
  12. return None
  13. while cur.val < low or cur.val > high:
  14. if cur.val < low:
  15. # 当前节点的值,比给的最小值要小,就需要把当前节点删除,并且比当前节点小的都要删除。
  16. # 有以下四种情况
  17. # 1:当前节点的左右子节点均为空,则直接删除节点,向上返回None
  18. if cur.left == None and cur.right == None:
  19. print("left==None and right==None")
  20. return None
  21. # 2:当前节点的左节点为空,右节点不为空,需要继续判断右节点的值是否在范围外
  22. elif cur.left == None and cur.right != None:
  23. cur = cur.right
  24. print(cur)
  25. # 3:当前节点的左节点不为空,右节点为空,因为是二叉搜索树,所以当前节点比左子树中的所有值都要大,则需要把当前节点和左子树的所有节点都删除
  26. elif cur.left != None and cur.right == None:
  27. return None
  28. # 4:当前节点的左右节点均不为空,左子树需要删除,右子树的值需要继续判断是否在范围外
  29. else:
  30. cur = cur.right
  31. print("you",cur)
  32. if cur.val > high:
  33. if cur.left == None and cur.right == None:
  34. return None
  35. elif cur.left == None and cur.right != None:
  36. return None
  37. elif cur.left != None and cur.right == None:
  38. cur = cur.left
  39. else:
  40. cur = cur.left
  41. print("zuo",cur)
  42. cur.left = deleteNode(cur.left)
  43. cur.right = deleteNode(cur.right)
  44. return cur
  45. return deleteNode(root)

        看了代码随想录的是视频后:

  1. # Definition for a binary tree node.
  2. # class TreeNode:
  3. # def __init__(self, val=0, left=None, right=None):
  4. # self.val = val
  5. # self.left = left
  6. # self.right = right
  7. class Solution:
  8. def trimBST(self, root: Optional[TreeNode], low: int, high: int) -> Optional[TreeNode]:
  9. if root == None:
  10. # 当前节点等于None,则向上返回None
  11. return None
  12. if root.val < low:
  13. # 当当前节点值小于范围的最小值时,当前节点的左子树的值就都小于最小值了
  14. # 当前节点的右子树中,可能有节点的值在范围内,可能有节点的值不在范围内
  15. # 因此继续向右进行遍历
  16. right = self.trimBST(root.right, low, high)
  17. return right
  18. if root.val > high:
  19. # 当当前节点值大于范围的最大值时,当前节点的右子树的值就都大于最大值了
  20. # 当前节点的左子树中,可能有节点的值在范围内,可能有节点的值不在范围内
  21. # 因此继续向左进行遍历
  22. left = self.trimBST(root.left, low, high)
  23. return left
  24. # 当节点的值在范围内,则继续向左右进行遍历
  25. root.left = self.trimBST(root.left, low, high)
  26. root.right = self.trimBST(root.right, low, high)
  27. return root

二、LeetCode108. 将有序数组转换为二叉搜索树

        1:题目描述(108. 将有序数组转换为二叉搜索树

        给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵 高度平衡 二叉搜索树。

        高度平衡 二叉树是一棵满足「每个节点的左右两个子树的高度差的绝对值不超过 1 」的二叉树。

        2:解题思路

  1. # Definition for a binary tree node.
  2. # class TreeNode:
  3. # def __init__(self, val=0, left=None, right=None):
  4. # self.val = val
  5. # self.left = left
  6. # self.right = right
  7. class Solution:
  8. def sortedArrayToBST(self, nums: List[int]) -> Optional[TreeNode]:
  9. if not nums:
  10. return None
  11. # 将数组中间的值作为根节点
  12. node_index = len(nums)//2
  13. # 定义节点
  14. node = TreeNode(nums[node_index])
  15. # 分割数组,左边为左子树的节点
  16. node_left = nums[:node_index]
  17. # 右边为右子树的节点
  18. node_right = nums[node_index+1:]
  19. # 获取节点的左右子树
  20. node.left = self.sortedArrayToBST(node_left)
  21. node.right = self.sortedArrayToBST(node_right)
  22. return node

三、LeetCode538. 把二叉搜索树转换为累加树

        1:题目描述(538. 把二叉搜索树转换为累加树

        给出二叉 搜索 树的根节点,该树的节点值各不相同,请你将其转换为累加树(Greater Sum Tree),使每个节点 node 的新值等于原树中大于或等于 node.val 的值之和。

        提醒一下,二叉搜索树满足下列约束条件:

  • 节点的左子树仅包含键 小于 节点键的节点。
  • 节点的右子树仅包含键 大于 节点键的节点。
  • 左右子树也必须是二叉搜索树。

        2:解题思路

  1. # Definition for a binary tree node.
  2. # class TreeNode:
  3. # def __init__(self, val=0, left=None, right=None):
  4. # self.val = val
  5. # self.left = left
  6. # self.right = right
  7. class Solution:
  8. def __init__(self):
  9. self.pre = 0
  10. def convertBST(self, root: Optional[TreeNode]) -> Optional[TreeNode]:
  11. # 本题使用的遍历顺序是:右中左
  12. if root == None:
  13. # 当节点为None,则返回None
  14. return None
  15. # 向右遍历
  16. self.convertBST(root.right)
  17. # 将pre的值与当前节点的值相加,作为当前节点的值
  18. root.val = root.val + self.pre
  19. # 再将当前节点的值,赋值给pre
  20. self.pre = root.val
  21. # 向左遍历
  22. self.convertBST(root.left)
  23. return root
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小惠珠哦/article/detail/910432
推荐阅读
相关标签
  

闽ICP备14008679号