日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

LeetCode 騰訊50題Python實(shí)現(xiàn)之《二叉樹中的最大路徑》

系統(tǒng) 1784 0

題目

給定一個(gè)非空二叉樹,返回其最大路徑和。

本題中,路徑被定義為一條從樹中任意節(jié)點(diǎn)出發(fā),達(dá)到任意節(jié)點(diǎn)的序列。該路徑至少包含一個(gè)節(jié)點(diǎn),且不一定經(jīng)過根節(jié)點(diǎn)。

示例 1:

輸入: [1,2,3]

            
                 1
  / \
 2   3

            
          

輸出: 6
示例 2:

輸入: [-10,9,20,null,null,15,7]

            
                -10
   / \
  9  20
    /  \
   15   7

            
          

輸出: 42

思路

關(guān)鍵是要求出,某一個(gè)根節(jié)點(diǎn)到某個(gè)子節(jié)點(diǎn)的最長路徑是多少。最后的結(jié)果一定是某一個(gè)根節(jié)點(diǎn)的值加上它左右子樹的那個(gè)最長路徑。
代碼如下,

代碼

ref:https://leetcode-cn.com/problems/two-sum/solution/di-gui-zhan-sheng-98-python-by-578123043/

            
              class Solution(object):
    def maxPathSum(self, root):
        maxx = [-999999]
#某一個(gè)根節(jié)點(diǎn)到某個(gè)子節(jié)點(diǎn)的最長路徑
        def maxsum(root):
            if root == None:
                return 0
            else:
                l = maxsum(root.left)
                r = maxsum(root.right) 
                result = max(root.val+max(l, r),0)
                maxx[0] =max(maxx[0] , root.val+l+r)
                return result
        maxsum(root)
        return maxx[0]



            
          

更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

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

【本文對(duì)您有幫助就好】

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

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 衡阳市| 云浮市| 清河县| 肇源县| 酒泉市| 丽江市| 阜城县| 望都县| 牙克石市| 肇州县| 海安县| 漳浦县| 嘉荫县| 和平县| 南丰县| 伊吾县| 达孜县| 和龙市| 大石桥市| 宁陕县| 通许县| 托克托县| 玉林市| 黄骅市| 仙游县| 和硕县| 灌云县| 永康市| 增城市| 丁青县| 金秀| 浙江省| 柳林县| 黄浦区| 苏尼特左旗| 清徐县| 宾川县| 新郑市| 万安县| 方山县| 平顶山市|