当前位置: 首页 > news >正文

Leetcode.1379 找出克隆二叉树中的相同节点

题目链接

Leetcode.1379 找出克隆二叉树中的相同节点 easy

题目描述

给你两棵二叉树,原始树 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,104][1, 10^4][1,104]
  • 同一棵树中,没有值相同的节点。
  • target节点是树 original中的一个节点,并且不会是 null

解法:递归

递归遍历 cloned,找到与 target值相同的结点返回即可。

时间复杂度: O(n)O(n)O(n)

C++代码:

class Solution {
public:TreeNode* getTargetCopy(TreeNode* original, TreeNode* cloned, TreeNode* target) {if(cloned == nullptr) return nullptr;if(cloned->val == target->val) return cloned;auto a = getTargetCopy(original,cloned->left,target);if(a != nullptr) return a;else return getTargetCopy(original,cloned->right,target);}
};

Python代码:


class Solution:def getTargetCopy(self, original: TreeNode, cloned: TreeNode, target: TreeNode) -> TreeNode:if cloned == None:return Noneif cloned.val == target.val:return cloneda = self.getTargetCopy(original,cloned.left,target)if a != None:return aelse:return self.getTargetCopy(original,cloned.right,target)   
http://www.lryc.cn/news/58222.html

相关文章:

  • 2022年团体程序设计天梯赛-总决赛
  • 大数据技术之Sqoop——SQL to Hadoop
  • Java议题
  • 【阅读论文】USAD:多变量时间序列上的无监督异常检测
  • Java多线程:ReentrantLock中的方法
  • RabbitMQ初识快速入门
  • 由浅入深了解HashMap源码
  • P5318 【深基18.例3】查找文献
  • Error caught was: No module named ‘triton‘
  • Ruby设计-开发日志
  • SpringBoot 调用外部接口的三种方式
  • C 中的结构体
  • nodejs安装教程
  • 【华为OD机试】1029 - 整数与IP地址间的转换
  • 【FPGA实验1】FPGA点灯工程师养成记
  • 操作系统论文导读(三):Stack-based scheduling of realtime processes基于堆栈的实时进程调度
  • 音频延时测试方法与实现
  • 在 Python 中管理机密的四种方法
  • 全国青少年信息素养大赛Python编程挑战赛初赛试题说明
  • 无需魔法打开即用的 AI 工具集锦
  • 如何进行SEO站内优化,让你的网站更易被搜索引擎收录
  • 组件内部watch后切换数据报错Error in callback for watcher “xxxx“
  • VMware ESXi 7.0 U3l macOS Unlocker OEM BIOS (标准版和厂商定制版)
  • 华为阿里版ChatGPT横空出世,谁的成效更好呢?
  • 【云原生之Docker实战】使用docker部署kooteam在线团队协作工具
  • ITSS认证是什么认证,itss资质认证
  • FTP-----局域网内部远程桌面
  • Learning C++ No.18【STL No.8】
  • pytorch搭建ResNet50实现鸟类识别
  • Node.js -- npm与包