563. Binary Tree Tilt

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

class Solution:
def findTilt(self, root):
"""
:type root: TreeNode
:rtype: int
"""
if not root:
return 0
return self.tilt(root)+self.findTilt(root.left)+self.findTilt(root.right)


def tilt(self,roo):
if not roo.right and not roo.left:
return 0
if not roo.right and roo.left:
return roo.left.val
if not roo.left and roo.right:
return roo.right.val
else:
return abs(roo.left.val-roo.right.val)

 

自己写的代码,理解题目意思出了问题,应该是左子树的和减去右子树的和

 

class Solution:
    def findTilt(self, root):
        """
        :type root: TreeNode
        :rtype: int
        """
        self.ans=0
        def sumnode(roo):
            if not roo:return 0
            left,right=sumnode(roo.left),sumnode(roo.right)
            self.ans+=abs(left-right)
            return roo.val+left+right
        sumnode(root)
        return self.ans

  

Runtime: 104 ms, faster than 68.09% of Python3 online submissions forBinary Tree Tilt.

 

class Solution:
    def findTilt(self, root):
        """
        :type root: TreeNode
        :rtype: int
        """
        tilt = [0]
        generate(root,tilt)
        return tilt[0]
        
def generate(node,tilt) :
    
    if not node :
        return 0 
    else :
        L = generate(node.left,tilt) 
        R = generate(node.right,tilt)
        
        tilt[0] += abs(L-R)
        
        return L + R + node.val

  

 

posted @ 2019-01-21 10:35  dgi  阅读(100)  评论(0编辑  收藏  举报