[LeetCode]669. Trim a Binary Search Tree

題目

Given a binary search tree and the lowest and highest boundaries as L and R, trim the tree so that all its elements lies in [L, R] (R >= L). You might need to change the root of the tree, so the result should return the new root of the trimmed binary search tree.

Example 1:

Input: 
    1
   / \
  0   2

  L = 1
  R = 2

Output: 
    1
      \
       2

Example 2:

Input: 
    3
   / \
  0   4
   \
    2
   /
  1

  L = 1
  R = 3

Output: 
      3
     / 
   2   
  /
 1

難度

Easy

方法

采用遞歸的方法。如果root為空,則直接返回root; 如果root的值<L,表示root及其左子樹所有節點都<L,那么需要改變root節點,從root.right中重新尋找root節點。同理,當root的值>R時,需要從root.left中重新尋找root節點。當L<=root.val<=R時,則遞歸處理root的左右子樹。

python代碼

class TreeNode(object):
    def __init__(self, x):
        self.val = x
        self.left = None
        self.right = None

class Solution(object):
    def trimBST(self, root, L, R):
        if root == None:
            return None

        if root.val < L:
            return self.trimBST(root.right, L, R)
        if root.val > R:
            return self.trimBST(root.left, L, R)

        root.left = self.trimBST(root.left, L, R)
        root.right = self.trimBST(root.right, L, R)

        return root

root = TreeNode(1)
root.left = TreeNode(0)
root.right = TreeNode(2)
assert Solution().trimBST(root, 3, 4) == None

root = TreeNode(3)
root.left = TreeNode(0)
root.right = TreeNode(4)
root.left.right = TreeNode(2)
root.left.right.left = TreeNode(1)
root = Solution().trimBST(root, 1, 3)
assert root.val == 3
assert root.left.val == 2
assert root.right == None
assert root.left.left.val == 1
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • 背景 一年多以前我在知乎上答了有關LeetCode的問題, 分享了一些自己做題目的經驗。 張土汪:刷leetcod...
    土汪閱讀 12,766評論 0 33
  • 以一顆熱情善良的心, 擁抱你們,呼喚未來, 得來的, 有以心換心,有虛情假意,有阿諛奉承…… 那就留下真情,驅走假...
    雨沐初心閱讀 210評論 0 0
  • 正買車的、剛買完的、超級車迷… 進群買車用車不走彎路 行車在路上,最討厭兩種狗, 遠光狗,加塞狗。 有些車友認為,...
    侃車人閱讀 326評論 0 0
  • 今兒有同學在群里分享記憶訓練方法,聽完之后,感慨良多~ 上學期間經歷過一次情感刺激,之后突然感覺自己的記憶力瞬...
    厚_德_載_物閱讀 309評論 0 1
  • 你決心說一個謊, 不止騙過所有的人。 也騙過南飛的大雁, 塞北的寬廣, 東流的河水, 和西歸的落陽。 那就先毀掉一...
    流村閱讀 241評論 0 2