• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Uriel's Corner

            Research Associate @ Harvard University / Research Interests: Computer Vision, Biomedical Image Analysis, Machine Learning
            posts - 0, comments - 50, trackbacks - 0, articles - 594
            給出一顆二叉搜索樹,求樹中數值范圍處于[low, high]的節點之和,DFS,如果當前節點處于[low, high],則左右子樹都要搜索,如果當前節點小于low,只需要搜索右子樹,如果當前節點大于high,只需要搜索左子樹,不過這題數據比較簡單,直接深搜完整棵樹,遇到處于[low, high]的節點就累加也可以過

            只搜索特定子樹:

             1 #938
             2 #Runtime: 284 ms
             3 #Memory: 29.9 MB
             4 
             5 # Definition for a binary tree node.
             6 # class TreeNode(object):
             7 #     def __init__(self, val=0, left=None, right=None):
             8 #         self.val = val
             9 #         self.left = left
            10 #         self.right = right
            11 class Solution(object):
            12     def rangeSumBST(self, root, low, high):
            13         """
            14         :type root: TreeNode
            15         :type low: int
            16         :type high: int
            17         :rtype: int
            18         """
            19         def DFS(r):
            20             if not r:
            21                 return 0
            22             if r.val >= low and r.val <= high:
            23                 return r.val + DFS(r.left) + DFS(r.right)
            24             if r.val < low:
            25                 return DFS(r.right)
            26             if r.val > high:
            27                 return DFS(r.left)
            28         return DFS(root)

            暴力搜完整棵樹:

             1 #938
             2 #Runtime: 535 ms
             3 #Memory: 29.5 MB
             4 
             5 # Definition for a binary tree node.
             6 # class TreeNode(object):
             7 #     def __init__(self, val=0, left=None, right=None):
             8 #         self.val = val
             9 #         self.left = left
            10 #         self.right = right
            11 class Solution(object):
            12     def rangeSumBST(self, root, low, high):
            13         """
            14         :type root: TreeNode
            15         :type low: int
            16         :type high: int
            17         :rtype: int
            18         """
            19         self.ans = 0
            20         def DFS(r):
            21             if not r:
            22                 return
            23             DFS(r.left)
            24             if r.val >= low and r.val <= high:
            25                 self.ans += r.val
            26             DFS(r.right)
            27         DFS(root)
            28         return self.ans
            久久精品国产亚洲AV嫖农村妇女| 国产精品99久久久久久人| 亚洲国产美女精品久久久久∴| 久久人爽人人爽人人片AV | 国产精品久久99| 精品久久久久久久久久久久久久久 | 久久影视综合亚洲| 亚洲精品乱码久久久久久按摩| 国产午夜久久影院| 一本一本久久a久久精品综合麻豆| 久久久久亚洲AV无码专区体验| 久久人人爽人人爽AV片| 久久Av无码精品人妻系列| 久久久久国产成人精品亚洲午夜| 久久亚洲欧美国产精品| 久久久精品国产| 青青草国产精品久久久久| 久久久婷婷五月亚洲97号色| 日韩精品久久久久久久电影| 久久久久成人精品无码 | 国产成人久久精品区一区二区| 久久免费视频1| 欧美一级久久久久久久大片| 97久久精品人妻人人搡人人玩| 无码伊人66久久大杳蕉网站谷歌| 色偷偷91久久综合噜噜噜噜| 久久久久久青草大香综合精品| 久久综合丁香激情久久| 久久国产精品成人影院| 综合久久一区二区三区 | 久久亚洲色一区二区三区| 国产亚洲精久久久久久无码AV| 久久福利青草精品资源站免费 | 国产精品美女久久久久网| 一本色道久久HEZYO无码| 久久精品国产亚洲av麻豆蜜芽| 伊人久久成人成综合网222| 久久男人AV资源网站| 久久久久九国产精品| 久久精品成人影院| 久久夜色精品国产亚洲av|