【题目】
给定一棵二叉树,返回所有重复的子树。对于同一类的重复子树,你只需要返回其中任意一棵的根结点即可。
两棵树重复是指它们具有相同的结构以及相同的结点值。
示例 1:
1
/ \
2 3
/ / \
4 2 4
/
4
下面是两个重复的子树:
2
/
4
和
4
因此,你需要以列表的形式返回上述重复子树的根结点。
【代码】
class Solution(object):
def findDuplicateSubtrees(self, root):
count = collections.Counter()
ans = []
def collect(node):
if not node: return "#"
serial = "{},{},{}".format(node.val, collect(node.left), collect(node.right))
count[serial] += 1
if count[serial] == 2:
ans.append(node)
return serial
collect(root)
return ans

这个博客讨论了一种算法,用于在给定的二叉树中查找所有重复的子树。算法通过创建一个计数器来跟踪每个子树的出现次数,并将子树序列化为字符串进行比较。当计数器达到2时,表示找到了重复的子树。示例展示了如何找到并返回这些重复子树的根节点。
69

被折叠的 条评论
为什么被折叠?



