You are given two binary trees root1
and root2
.
Imagine that when you put one of them to cover the other, some nodes of the two trees are overlapped while the others are not. You need to merge the two trees into a new binary tree. The merge rule is that if two nodes overlap, then sum node values up as the new value of the merged node. Otherwise, the NOT null node will be used as the node of the new tree.
Return the merged tree.
Note: The merging process must start from the root nodes of both trees.
Example 1:
Input: root1 = [1,3,2,5], root2 = [2,1,3,null,4,null,7] Output: [3,4,5,5,4,null,7]
Example 2:
Input: root1 = [1], root2 = [1,2] Output: [2,2]
Constraints:
- The number of nodes in both trees is in the range
[0, 2000]
. -104 <= Node.val <= 104
Companies:
Amazon, Facebook, Microsoft, Adobe, Bloomberg
Related Topics:
Tree, Depth-First Search, Breadth-First Search, Binary Tree
Simply follow the question description, you'll get the following recursive solution.
// OJ: https://leetcode.com/problems/merge-two-binary-trees
// Author: github.com/lzl124631x
// Time: O(N)
// Space: O(H)
class Solution {
public:
TreeNode* mergeTrees(TreeNode* a, TreeNode* b) {
if (!a || !b) return a ? a : b;
auto node = new TreeNode(a->val + b->val);
node->left = mergeTrees(a->left, b->left);
node->right = mergeTrees(a->right, b->right);
return node;
}
};
This solution is accepted by the OJ. But in real world, this solution generates a tree that has not only new nodes merged from old trees, but also pointers to the old trees. It means that if you destroy the old trees, the newly merged tree will be broken. To avoid this, use solution 2.
This solution is same as solution 1 except that for non-overlapping parts, it copy constructs the nodes.
// OJ: https://leetcode.com/problems/merge-two-binary-trees
// Author: github.com/lzl124631x
// Time: O(N)
// Space: O(H)
class Solution {
TreeNode *copy(TreeNode *root) {
if (!root) return NULL;
auto node = new TreeNode(root->val);
node->left = copy(root->left);
node->right = copy(root->right);
return node;
}
public:
TreeNode* mergeTrees(TreeNode* a, TreeNode* b) {
if (!a || !b) return a ? copy(a) : copy(b);
auto node = new TreeNode(a->val + b->val);
node->left = mergeTrees(a->left, b->left);
node->right = mergeTrees(a->right, b->right);
return node;
}
};