当前位置:   article > 正文

搜索--找出克隆二叉树中的相同节点

搜索--找出克隆二叉树中的相同节点

题目描述

给你两棵二叉树,原始树 original 和克隆树 cloned,以及一个位于原始树 original 中的目标节点 target

其中,克隆树 cloned 是原始树 original 的一个 副本 

请找出在树 cloned 中,与 target 相同 的节点,并返回对该节点的引用(在 C/C++ 等有指针的语言中返回 节点指针,其他语言返回节点本身)。

注意:你 不能 对两棵二叉树,以及 target 节点进行更改。只能 返回对克隆树 cloned 中已有的节点的引用。

示例 1:

输入: tree = [7,4,3,null,null,6,19], target = 3
输出: 3
解释: 上图画出了树 original 和 cloned。target 节点在树 original 中,用绿色标记。答案是树 cloned 中的黄颜色的节点(其他示例类似)。

示例 2:

输入: tree = [7], target =  7
输出: 7

示例 3:

输入: tree = [8,null,6,null,5,null,4,null,3,null,2,null,1], target = 4
输出: 4

提示:

  • 树中节点的数量范围为 [1, 10^4] 。
  • 同一棵树中,没有值相同的节点。
  • target 节点是树 original 中的一个节点,并且不会是 null 。

1. 思路

直接用深搜或者广搜即可。

2. 代码

  1. public class TreeNode {
  2. int val;
  3. TreeNode left;
  4. TreeNode right;
  5. TreeNode() {}
  6. TreeNode(int val) { this.val = val; }
  7. TreeNode(int val, TreeNode left, TreeNode right) {
  8. this.val = val;
  9. this.left = left;
  10. this.right = right;
  11. }
  12. }
  13. TreeNode ans;
  14. public final TreeNode getTargetCopy(final TreeNode original, final TreeNode cloned, final TreeNode target) {
  15. dfs(cloned,target);
  16. return ans;
  17. }
  18. public void dfs(TreeNode cloned, TreeNode target){
  19. if(cloned!=null){
  20. if(cloned.val==target.val) {
  21. ans=cloned;
  22. return;
  23. }
  24. dfs(cloned.left,target);
  25. dfs(cloned.right,target);
  26. }
  27. }

3. 参考题目

. - 力扣(LeetCode)

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/凡人多烦事01/article/detail/365315?site
推荐阅读
相关标签
  

闽ICP备14008679号