Binary Tree in Action (Post-order)
This article will resolve
LeetCode | Difficulty |
---|---|
652. Find Duplicate Subtrees | 🟠 |
Prerequisite Knowledge
Before reading this article, you need to study:
This article is the fourth in the series following Essence of Binary Trees (Guideline), focusing on the effective use of post-order positions in binary trees. Let's recap the description of post-order traversal from the previous articles:
In the pre-order position, the code can only obtain data passed from the parent node through function parameters, whereas in the post-order position, the code can access both parameter data and data returned by the subtrees.
In other words, if you notice that a problem is related to subtrees, you likely need to define appropriate function definitions and return values, and write code in the post-order position.
Without further ado, let's look at a problem: LeetCode Problem 652, "Find Duplicate Subtrees":
652. Find Duplicate Subtrees | LeetCode | 🟠
Given the root
of a binary tree, return all duplicate subtrees.
For each kind of duplicate subtrees, you only need to return the root node of any one of them.
Two trees are duplicate if they have the same structure with the same node values.
Example 1:
data:image/s3,"s3://crabby-images/8f0ba/8f0ba3941b72733a86a2f9c6ed86bc8334e8b876" alt=""
Input: root = [1,2,3,4,null,2,4,null,null,4] Output: [[2,4],[4]]
Example 2:
data:image/s3,"s3://crabby-images/3a522/3a522311a6c507c1e454e420d31c16b14a0019e6" alt=""
Input: root = [2,1,1] Output: [[1]]
Example 3:
data:image/s3,"s3://crabby-images/6eae4/6eae4a9099bca5c92b55b7f950cf7973225b0019" alt=""
Input: root = [2,2,2,3,null,3,null] Output: [[2,3],[3]]
Constraints:
- The number of the nodes in the tree will be in the range
[1, 5000]
-200 <= Node.val <= 200
// function signature as follows
List<TreeNode> findDuplicateSubtrees(TreeNode root);
// The function signature is as follows
vector<TreeNode*> findDuplicateSubtrees(TreeNode* root);
# The function signature is as follows
def findDuplicateSubtrees(self, root: TreeNode) -> List[TreeNode]:
// The function signature is as follows
func findDuplicateSubtrees(root *TreeNode) []*TreeNode
// The function signature is as follows
var findDuplicateSubtrees = function(root) {}
Let me briefly explain the problem. The input is the root node root
of a binary tree, and the output is a list containing several binary tree nodes. These nodes correspond to subtrees that have duplicates in the original binary tree.
It might sound a bit complex, so let's look at an example. Consider the following binary tree:
data:image/s3,"s3://crabby-images/78653/7865381ae36bb71f2b06b74f20b9a716ef9376fa" alt=""
First, node 4 itself can be considered a subtree, and there are multiple nodes with the value 4 in the tree:
data:image/s3,"s3://crabby-images/ade38/ade38f060453b113435111f56f24287138b6d8bd" alt=""
Similarly, there are also two duplicate subtrees with 2 as the root:
data:image/s3,"s3://crabby-images/76ab1/76ab18c6e3920635d8aee7cfb46f96dd9d47631d" alt=""
Therefore, the List
we return should contain two TreeNode
elements, with values 4 and 2 (the specific nodes do not matter).