码迷,mamicode.com
首页 > 其他好文 > 详细

树的子结构(1)

时间:2020-04-25 01:15:08      阅读:58      评论:0      收藏:0      [点我收藏+]

标签:binary   bsp   python   you   not   solution   http   nbsp   商业   

技术图片

 

 

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None
#先是比较树根左右边的是否相等。如果没有在进入三角处理。
class Solution:
    def isSubStructure(self, A: TreeNode, B: TreeNode) -> bool:
        if A == None or B == None:
            return False
        return self.dfs(A,B) or self.isSubStructure(A.left,B) or self.isSubStructure(A.right,B)
    
    def dfs(self, A: TreeNode, B: TreeNode) -> bool:
        if B == None:
            return True
        if A == None:
            return False
        return A.val == B.val and self.dfs(A.left,B.left) and self.dfs(A.right,B.right)


作者:mu-qian-ruo-chi
链接:https://leetcode-cn.com/problems/shu-de-zi-jie-gou-lcof/solution/pythondi-gui-shen-du-you-xian-sou-suo-by-mu-qian-r/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

 

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

class Solution:
    def isSubStructure(self, A: TreeNode, B: TreeNode) -> bool:
        def recur(A, B):
            if not B: return True
            if not A or A.val != B.val: return False
            return recur(A.left, B.left) and recur(A.right, B.right)

        return bool(A and B) and (recur(A, B) or self.isSubStructure(A.left, B) or self.isSubStructure(A.right, B))

        

 

树的子结构(1)

标签:binary   bsp   python   you   not   solution   http   nbsp   商业   

原文地址:https://www.cnblogs.com/topass123/p/12770939.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!