Be the first user to complete this post
|
Add to List |
46. Check if One Binary Tree is a Subtree of Another
Objective: Given two binary trees, check if one binary tree is a subtree of another
Example:
data:image/s3,"s3://crabby-images/195ef/195efbceb9a045e3f042a388caedfd020fe364f9" alt="Tree is subtree of another tree example"
Approach:
We know that identifying any binary tree can be represented as the combination of either inorder and preorder traversal OR inorder and postorder traversal OR inorder and Level order traversal.
- Say our trees are A and B.
- Do the inorder traversal of treeA and store it in a String say inorderA.
- Do the inorder traversal of treeB and store it in a String say inorderB.
- Do the postorder traversal of treeA and store it in a String say postorderA.
- Do the postorder traversal of treeB and store it in a String say postorderB.
- Check if inorderA contains inorderB AND postorderA contains postorderB then it means treeB is a subtree of treeA.
Time Complexity : O(n)
data:image/s3,"s3://crabby-images/c0d85/c0d859c04aa363aaef98b969d0df28f365c83b05" alt="Tree is subtree of another tree"
Tree A : 3 2 1 5 4 6
Tree B : 5 4 6
true