题目
给定两个二叉树,想象当你将它们中的一个覆盖到另一个上时,两个二叉树的一些节点便会重叠。
你需要将他们合并为一个新的二叉树。合并的规则是如果两个节点重叠,那么将他们的值相加作为节点合并后的新值,否则不为 NULL 的节点将直接作为新二叉树的节点。
示例
分析:
采用递归法,递归思想总共分为三大要素:
第一要素:明确你这个函数想要干什么:
给这两棵二叉树进行前序遍历,并让值相加,赋值给t1树上
第二要素: 寻找递归结束条件:
谁是null就返回另一个树的节点。
第三要素:找出函数的等价关系式
t1.value= t1.value+t2.value
递归思想请参考:http://www.ztinfo.xyz/archives/%E9%80%92%E5%BD%92%E7%AE%97%E6%B3%95
代码如下:
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
public TreeNode mergeTrees(TreeNode t1, TreeNode t2) {
if(t1 == null){
return t2;
}
if(t2 == null){
return t1;
}
t1.val+=t2.val;
//递归
t1.left = mergeTrees(t1.left,t2.left);
t1.right = mergeTrees(t1.right,t2.right);
return t1;
}