首页 > 其他 > 详细

leetcode-337-打家劫舍三*

时间:2019-07-20 21:09:30      阅读:84      评论:0      收藏:0      [点我收藏+]

题目描述:

技术分享图片

技术分享图片

 方法一:递归

# 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 rob(self, root):
        """
        :type root: TreeNode
        :rtype: int
        """
        def postorder(root): 
            if root == None: 
                return (0,0) 
            l = postorder(root.left) 
            r = postorder(root.right) 
            return (root.val+l[1]+r[1] , max(l[0], l[1])+ max( r[0], r[1])) 
        r = postorder(root) 
        return max(r[0],r[1])

另:

# Definition for a binary tree node.
# class TreeNode(object):
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None

cache = {} 
def max_with_root(node): 
    return node.val + max_without_root(node.left) + max_without_root(node.right) if node else 0 

def max_without_root(node): 
    return helper(node.left) + helper(node.right) if node else 0 

def helper(node): 
    if node in cache: return cache[node] 
    cache[node] = max(max_with_root(node), max_without_root(node)) if node else 0 
    return cache[node] 

class Solution(object): 
    def rob(self, root): 
        """
        :type root: TreeNode
        :rtype: int
        """ 
        return helper(root)

 

leetcode-337-打家劫舍三*

原文:https://www.cnblogs.com/oldby/p/11219004.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!