给定二叉搜索树(BST)的根节点 root
和一个整数值 val
。
你需要在 BST 中找到节点值等于 val
的节点。 返回以该节点为根的子树。 如果节点不存在,则返回 null
。
示例 1:
输入:root = [4,2,7,1,3], val = 2 输出:[2,1,3]示例 2:
输入:root = [4,2,7,1,3], val = 5 输出:[]
输出这么写我总以为是返回子树值的列表,结果是直接返回子树根节点
原来二叉搜索树就是二叉排序树,然而我直接暴力深搜。。。
- # Definition for a binary tree node.
- # class TreeNode(object):
- # def __init__(self, val=0, left=None, right=None):
- # self.val = val
- # self.left = left
- # self.right = right
- class Solution(object):
- def searchBST(self, root, val):
- """
- :type root: TreeNode
- :type val: int
- :rtype: TreeNode
- """
- childRoot = None
- def nextLevel(root, val):
- if root.val == val:
- return root
- if root.left:
- targetLeft = nextLevel(root.left, val)
- if targetLeft:
- return targetLeft
- if root.right:
- targetRight = nextLevel(root.right, val)
- if targetRight:
- return targetRight
- return None
-
- if root.val == val:
- return root
- if root.left:
- childRoot = nextLevel(root.left, val)
- if not childRoot and root.right:
- childRoot = nextLevel(root.right, val)
- return childRoot
给定一个二叉搜索树的根节点 root 和一个值 key,删除二叉搜索树中的 key 对应的节点,并保证二叉搜索树的性质不变。返回二叉搜索树(有可能被更新)的根节点的引用。
一般来说,删除节点可分为两个步骤:
示例 1:
输入:root = [5,3,6,2,4,null,7], key = 3 输出:[5,4,6,2,null,null,7] 解释:给定需要删除的节点值是 3,所以我们首先找到 3 这个节点,然后删除它。 一个正确的答案是 [5,4,6,2,null,null,7], 如下图所示。 另一个正确答案是 [5,2,6,null,4,null,7]。示例 2:
输入: root = [5,3,6,2,4,null,7], key = 0 输出: [5,3,6,2,4,null,7] 解释: 二叉树不包含值为 0 的节点示例 3:
输入: root = [], key = 0 输出: []
写不出来,直接看评论题解了
这个方法最妙的地方就是把要删除的节点看成根节点
然后以目标节点为根,分情况:
- # Definition for a binary tree node.
- # class TreeNode(object):
- # def __init__(self, val=0, left=None, right=None):
- # self.val = val
- # self.left = left
- # self.right = right
- class Solution(object):
- def deleteNode(self, root, key):
- """
- :type root: TreeNode
- :type key: int
- :rtype: TreeNode
- """
- if not root:
- return None
- if key == root.val:
- if not (root.left or root.right):
- return None
- elif not root.left:
- return root.right
- elif not root.right:
- return root.left
- else:
- rMin = root.right
- while rMin.left: #找到右子树里的最小值节点放到要删除的节点去
- rMin = rMin.left
- rMin.right = self.deleteNode(root.right, rMin.val) #删除原来右子树里的最小值节点
- rMin.left = root.left
- return rMin
- if key < root.val:
- root.left = self.deleteNode(root.left, key)
- if key > root .val:
- root.right = self.deleteNode(root.right,key)
- return root