leetcode 617. 合并二叉树 基础递归
程序员文章站
2022-05-20 10:31:20
...
- 合并二叉树
给定两个二叉树,想象当你将它们中的一个覆盖到另一个上时,两个二叉树的一些节点便会重叠。
你需要将他们合并为一个新的二叉树。合并的规则是如果两个节点重叠,那么将他们的值相加作为节点合并后的新值,否则不为 NULL 的节点将直接作为新二叉树的节点。
示例 1:
输入:
Tree 1 Tree 2
1 2
/ \ / \
3 2 1 3
/ \ \
5 4 7
输出:
合并后的树:
3
/ \
4 5
/ \ \
5 4 7
注意: 合并必须从两个树的根节点开始。
基础递归,mergeTrees
返回合并好的树,
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
TreeNode* mergeTrees(TreeNode* a, TreeNode* b) {
if(!a && b) return b;
if(a && !b) return a;
if(a && b) {
a->left = mergeTrees(a->left, b->left);
a->right = mergeTrees(a->right, b->right);
a->val += b->val;
}
return a;
}
};
java
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
class Solution {
public TreeNode mergeTrees(TreeNode a, TreeNode b) {
if(a == null && b != null)
return b;
if(a != null && b == null)
return a;
if(a != null && b != null) {
a.left = mergeTrees(a.left, b.left);
a.right = mergeTrees(a.right, b.right);
a.val += b.val;
}
return a;
}
}
推荐阅读
-
leetcode 101. 对称二叉树 递归解法
-
【LeetCode】二叉树各种遍历大汇总(秒杀前序、中序、后序、层序)递归 & 迭代
-
leadcode的Hot100系列--617. 合并二叉树
-
LeetCode刷题(117)~二叉树的中序遍历【递归|迭代】
-
LeetCode 94. 二叉树的中序遍历(递归)(迭代)
-
LeetCode 二叉树的中序遍历(递归和非递归算法)
-
【基础题】--实现二叉树的前序 / 中序 / 后序非递归遍历
-
LeetCode 655. 输出二叉树(层次遍历、递归)
-
LeetCode 105. 从前序与中序遍历序列构造二叉树(各种遍历二叉树的性质,递归建树)
-
LeetCode 654. 最大二叉树(递归建树)