题目描述给你两棵二叉树root1和root2。想象一下当你将其中一棵覆盖到另一棵之上时两棵树上的一些节点将会重叠而另一些不会。你需要将这两棵树合并成一棵新二叉树。合并的规则是如果两个节点重叠那么将这两个节点的值相加作为合并后节点的新值否则不为null 的节点将直接作为新二叉树的节点。返回合并后的二叉树。注意:合并过程必须从两个树的根节点开始。示例 1输入root1 [1,3,2,5], root2 [2,1,3,null,4,null,7] 输出[3,4,5,5,4,null,7]示例 2输入root1 [1], root2 [1,2] 输出[2,2]提示两棵树中的节点数目在范围[0, 2000]内-10^4 Node.val 10^4代码/** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode() {} * TreeNode(int val) { this.val val; } * TreeNode(int val, TreeNode left, TreeNode right) { * this.val val; * this.left left; * this.right right; * } * } */classSolution{publicTreeNodemergeTrees(TreeNoderoot1,TreeNoderoot2){// 确定遍历终止条件if(root1null)returnroot2;if(root2null)returnroot1;// 前序遍历 处理中间节点// 借用root1节点作为返回节点root1.valroot1.valroot2.val;if(root1.left!null||root2.left!null)root1.leftmergeTrees(root1.left,root2.left);if(root1.right!null||root2.right!null)root1.rightmergeTrees(root1.right,root2.right);returnroot1;}}
LeetCode--617.合并二叉树(二叉树)
发布时间:2026/5/28 10:05:56
题目描述给你两棵二叉树root1和root2。想象一下当你将其中一棵覆盖到另一棵之上时两棵树上的一些节点将会重叠而另一些不会。你需要将这两棵树合并成一棵新二叉树。合并的规则是如果两个节点重叠那么将这两个节点的值相加作为合并后节点的新值否则不为null 的节点将直接作为新二叉树的节点。返回合并后的二叉树。注意:合并过程必须从两个树的根节点开始。示例 1输入root1 [1,3,2,5], root2 [2,1,3,null,4,null,7] 输出[3,4,5,5,4,null,7]示例 2输入root1 [1], root2 [1,2] 输出[2,2]提示两棵树中的节点数目在范围[0, 2000]内-10^4 Node.val 10^4代码/** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode() {} * TreeNode(int val) { this.val val; } * TreeNode(int val, TreeNode left, TreeNode right) { * this.val val; * this.left left; * this.right right; * } * } */classSolution{publicTreeNodemergeTrees(TreeNoderoot1,TreeNoderoot2){// 确定遍历终止条件if(root1null)returnroot2;if(root2null)returnroot1;// 前序遍历 处理中间节点// 借用root1节点作为返回节点root1.valroot1.valroot2.val;if(root1.left!null||root2.left!null)root1.leftmergeTrees(root1.left,root2.left);if(root1.right!null||root2.right!null)root1.rightmergeTrees(root1.right,root2.right);returnroot1;}}