题目内容
给你两棵二叉树,原始树 original 和克隆树 cloned,以及一个位于原始树 original 中的目标节点 target。
其中,克隆树 cloned 是原始树 original 的一个 副本 。
请找出在树 cloned 中,与 target 相同 的节点,并返回对该节点的引用(在 C/C++ 等有指针的语言中返回 节点指针,其他语言返回节点本身)。
注意:
你 不能 对两棵二叉树,以及 target 节点进行更改。
只能 返回对克隆树 cloned 中已有的节点的引用。

进阶:如果树中允许出现值相同的节点,你将如何解答?
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/find-a-corresponding-node-of-a-binary-tree-in-a-clone-of-that-tree
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
Java解答
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
class Solution {
public final TreeNode getTargetCopy(final TreeNode original, final TreeNode cloned, final TreeNode target) {
return DFS(cloned,target.val);
}
public TreeNode DFS(TreeNode root,int target){
if(root==null){
return null;
}
if(root.val==target){
return root;
}
TreeNode left=DFS(root.left,target);
if(left!=null){
return left;
}
return DFS(root.right,target);
}
}
该博客讨论了如何在给定的克隆二叉树中找到与原始树中特定目标节点相同的一个节点。通过使用深度优先搜索(DFS)策略,可以有效地找到目标节点的副本。算法在不修改原始树或目标节点的情况下,仅返回克隆树中的对应节点引用。
560

被折叠的 条评论
为什么被折叠?



