欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

(Python)

系統 1607 0

題目描述

Given the root node of a binary search tree, return the sum of values of all nodes with value between L and R (inclusive).

The binary search tree is guaranteed to have unique values.

Example 1:

Input: root = [10,5,15,3,7,null,18], L = 7, R = 15
Output: 32

Example 2:

Input: root = [10,5,15,3,7,13,18,1,null,6], L = 6, R = 10
Output: 23

Note:

The number of nodes in the tree is at most 10000.
The final answer is guaranteed to be less than 2^31.

            
              
                # Definition for a binary tree node.
              
              
                # class TreeNode(object):
              
              
                #     def __init__(self, x):
              
              
                #         self.val = x
              
              
                #         self.left = None
              
              
                #         self.right = None
              
              
                class
              
              
                Solution
              
              
                (
              
              
                object
              
              
                )
              
              
                :
              
              
                def
              
              
                rangeSumBST
              
              
                (
              
              self
              
                ,
              
               root
              
                ,
              
               L
              
                ,
              
               R
              
                )
              
              
                :
              
              
                """
        :type root: TreeNode
        :type L: int
        :type R: int
        :rtype: int
        """
              
              
                if
              
              
                not
              
               root
              
                :
              
              
                return
              
              
                0
              
              
        res 
              
                =
              
              
                0
              
              
                if
              
               L 
              
                <=
              
               root
              
                .
              
              val 
              
                <=
              
               R
              
                :
              
              
            res 
              
                +=
              
               root
              
                .
              
              val
            res 
              
                +=
              
               self
              
                .
              
              rangeSumBST
              
                (
              
              root
              
                .
              
              left
              
                ,
              
               L
              
                ,
              
               R
              
                )
              
              
            res 
              
                +=
              
               self
              
                .
              
              rangeSumBST
              
                (
              
              root
              
                .
              
              right
              
                ,
              
               L
              
                ,
              
               R
              
                )
              
              
                elif
              
               root
              
                .
              
              val 
              
                <
              
               L
              
                :
              
              
            res 
              
                +=
              
               self
              
                .
              
              rangeSumBST
              
                (
              
              root
              
                .
              
              right
              
                ,
              
               L
              
                ,
              
               R
              
                )
              
              
                elif
              
               root
              
                .
              
              val 
              
                >
              
               R
              
                :
              
              
            res 
              
                +=
              
               self
              
                .
              
              rangeSumBST
              
                (
              
              root
              
                .
              
              left
              
                ,
              
               L
              
                ,
              
               R
              
                )
              
              
                return
              
               res

            
          

簡化代碼:直接判斷尋找的方向。如果root節點小于R,說明右邊可以繼續搜索;如果root節點大于L,說明左邊可以繼續搜索。

            
              
                # Definition for a binary tree node.
              
              
                # class TreeNode(object):
              
              
                #     def __init__(self, x):
              
              
                #         self.val = x
              
              
                #         self.left = None
              
              
                #         self.right = None
              
              
                class
              
              
                Solution
              
              
                (
              
              
                object
              
              
                )
              
              
                :
              
              
                def
              
              
                rangeSumBST
              
              
                (
              
              self
              
                ,
              
               root
              
                ,
              
               L
              
                ,
              
               R
              
                )
              
              
                :
              
              
                """
        :type root: TreeNode
        :type L: int
        :type R: int
        :rtype: int
        """
              
              
        res 
              
                =
              
              
                [
              
              
                0
              
              
                ]
              
              
        self
              
                .
              
              dfs
              
                (
              
              root
              
                ,
              
               L
              
                ,
              
               R
              
                ,
              
               res
              
                )
              
              
                return
              
               res
              
                [
              
              
                0
              
              
                ]
              
              
                def
              
              
                dfs
              
              
                (
              
              self
              
                ,
              
               root
              
                ,
              
               L
              
                ,
              
               R
              
                ,
              
               res
              
                )
              
              
                :
              
              
                if
              
              
                not
              
               root
              
                :
              
              
                return
              
              
                if
              
               L 
              
                <=
              
               root
              
                .
              
              val 
              
                <=
              
               R
              
                :
              
              
            res
              
                [
              
              
                0
              
              
                ]
              
              
                +=
              
               root
              
                .
              
              val
        
              
                if
              
               root
              
                .
              
              val 
              
                <
              
               R
              
                :
              
              
            self
              
                .
              
              dfs
              
                (
              
              root
              
                .
              
              right
              
                ,
              
               L
              
                ,
              
               R
              
                ,
              
               res
              
                )
              
              
                if
              
               root
              
                .
              
              val 
              
                >
              
               L
              
                :
              
              
            self
              
                .
              
              dfs
              
                (
              
              root
              
                .
              
              left
              
                ,
              
               L
              
                ,
              
               R
              
                ,
              
               res
              
                )
              
            
          

參考來源:https://blog.csdn.net/fuxuemingzhu/article/details/83961263


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 精品视频一区二区三区 | 午夜影视在线观看 | 欧美黄色免费网站 | 青青草91视频 | 久久草在线视频国产一 | 免费视频片在线观看大片 | 亚洲精品日韩在线 | 欧美一级久久久久久久大片 | 欧美精品一区二区三区在线 | 欧美日韩亚洲人人夜夜澡 | 99久久99久久免费精品蜜桃 | 亚洲精品久久久 | tube69欧美最新片 | 亚洲日本片 | 在线免费观看h片 | 免费看一区二区三区 | 中文字幕在线免费观看 | 亚洲欧美日韩一区二区 | 亚洲网站色 | 日日摸夜夜摸人人嗷嗷叫 | 国产精品福利资源在线 | 欧美亚洲国产另类在线观看 | 一级做a爰性色毛片免费 | 青青草国产精品欧美成人 | 九九久久精品这里久久网 | 黄色片的网站 | 五月婷婷综合在线视频 | 日产国产欧美视频一区精品 | 色婷婷精品国产一区二区三区 | 亚洲高清国产品国语在线观看 | 国产免费小视频在线观看 | 欧美激情免费观看一区 | 手机成人在线视频 | 五月婷丁香 | 97精品国产高清久久久久蜜芽 | 午夜精品久久久久久久90蜜桃 | 欧美激情在线精品一区二区 | 韩国A片国产浪潮AV 久久99国产精品 | 久久久99精品免费观看精品 | 高清中文字幕视频在线播 | 咪咪色在线视频 |