interview_prepare_binarytree

Posted zijidan

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了interview_prepare_binarytree相关的知识,希望对你有一定的参考价值。

1.pathSum

 1 class TreeNode:
 2     def __init__(self,x):
 3         self.val=x
 4         self.left=None
 5         self.right=None
 6 
 7 
 8 class Solution:
 9     def dfs(self,root,target,path):
10         if(root.left==None and root.right==None and root.val+sum(path)==target):
11             self.res.append(path+[root.val])
12             return
13         
14         if(root.left):
15             self.dfs(root.left,target,path+[root.val])
16         
17         if(root.right):
18             self.dfs(root.right,target,path+[root.val])
19 
20     def pathSum_dfs(self,root,target):
21         self.res=[]
22         if(not root):
23             return []
24 
25         self.dfs(root,target,[])
26 
27         return self.res
28 
29 
30 
31 
32 root=TreeNode(5)
33 l11=TreeNode(4)
34 l12=TreeNode(8)
35 l21=TreeNode(11)
36 l23=TreeNode(13)
37 l24=TreeNode(4)
38 l31=TreeNode(7)
39 l32=TreeNode(2)
40 l35=TreeNode(5)
41 l36=TreeNode(1)
42 
43 root.left=l11
44 root.right=l12
45 l11.left=l21
46 l12.left=l23
47 l12.right=l24
48 l21.left=l31
49 l21.right=l32
50 l24.left=l35
51 l24.right=l36
52 
53 print(Solution().pathSum_dfs(root,22))

 

# 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 dfs(self,root,target,path):
        if(root.left==None and root.right==None and root.val+sum(path)==target):
            self.res.append(path+[root.val])
            return
        
        if(root.left):
            self.dfs(root.left,target,path+[root.val])
        
        if(root.right):
            self.dfs(root.right,target,path+[root.val])


    def pathSum(self, root, sum):
        self.res=[]
        if(not root):
            return []

        self.dfs(root,sum,[])

        return self.res

以上是关于interview_prepare_binarytree的主要内容,如果未能解决你的问题,请参考以下文章