【LeetCode每日一题】——617.合并二叉树
创始人
2024-06-02 09:53:37
0

文章目录

  • 一【题目类别】
  • 二【题目难度】
  • 三【题目编号】
  • 四【题目描述】
  • 五【题目示例】
  • 六【解题思路】
  • 七【题目提示】
  • 八【时间频度】
  • 九【代码实现】
  • 十【提交结果】

一【题目类别】

  • 深度优先搜索

二【题目难度】

  • 简单

三【题目编号】

  • 617.合并二叉树

四【题目描述】

  • 给你两棵二叉树: 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]内两棵树中的节点数目在范围 [0, 2000] 内两棵树中的节点数目在范围[0,2000]内
  • −104<=Node.val<=104-10^4 <= Node.val <= 10^4−104<=Node.val<=104

八【时间频度】

  • 时间复杂度:O(min(m,n))O(min(m,n))O(min(m,n)),其中m,nm,nm,n分别为传入的两棵二叉树的节点个数
  • 空间复杂度:O(min(m,n))O(min(m,n))O(min(m,n)),其中m,nm,nm,n分别为传入的两棵二叉树的节点个数

九【代码实现】

  1. Java语言版
class Solution {public TreeNode mergeTrees(TreeNode root1, TreeNode root2) {if(root1 == null){return root2;}if(root2 == null){return root1;}root1.val = root1.val + root2.val;root1.left = mergeTrees(root1.left,root2.left);root1.right = mergeTrees(root1.right,root2.right);return root1; }
}
  1. C语言版
struct TreeNode* mergeTrees(struct TreeNode* root1, struct TreeNode* root2)
{if(root1 == NULL){return root2;}if(root2 == NULL){return root1;}root1->val = root1->val + root2->val;root1->left = mergeTrees(root1->left,root2->left);root1->right = mergeTrees(root1->right,root2->right);return root1;
}
  1. Python语言版
class Solution:def mergeTrees(self, root1: Optional[TreeNode], root2: Optional[TreeNode]) -> Optional[TreeNode]:if root1 is None:return root2if root2 is None:return root1root1.val = root1.val + root2.valroot1.left = self.mergeTrees(root1.left,root2.left)root1.right = self.mergeTrees(root1.right,root2.right)return root1
  1. C++语言版
class Solution {
public:TreeNode* mergeTrees(TreeNode* root1, TreeNode* root2) {if(root1 == nullptr){return root2;}if(root2 == nullptr){return root1;}root1->val = root1->val + root2->val;root1->left = mergeTrees(root1->left,root2->left);root1->right = mergeTrees(root1->right,root2->right);return root1;}
};

十【提交结果】

  1. Java语言版
    在这里插入图片描述

  2. C语言版
    在这里插入图片描述

  3. Python语言版
    在这里插入图片描述

  4. C++语言版
    在这里插入图片描述

上一篇:MySQL调优补充

下一篇:ROS项目的GDB调试

相关内容

热门资讯

安卓系统账号怎么改,轻松实现账... 你是不是也和我一样,在使用安卓手机的时候,突然觉得账号名字太老土了,想要来个焕然一新的改变呢?别急,...
离线语音系统安卓版下载,随时随... 你有没有想过,在手机上也能实现语音助手的功能,而且完全不需要联网?没错,就是那种离线语音系统,听起来...
华为os系统是基于安卓系统吗,... 你有没有想过,华为的手机里那个神秘的OS系统,它是不是就是安卓系统呢?别急,今天就来揭开这个谜底,让...
各品牌安卓系统多大,探索各大品... 你有没有想过,那些我们每天离不开的安卓手机,它们背后的系统到底有多大呢?这可不是一个小问题哦,因为系...
不是安卓系统电视机,探索非安卓... 你有没有想过,家里的电视是不是安卓系统呢?现在市面上,安卓系统电视机可是越来越流行了。但是,你知道吗...
谷歌安卓系统开源免费用,免费体... 你知道吗?在科技的世界里,有时候最让人惊喜的就是那些免费又好用的东西。今天,就让我来给你揭秘一个超级...
安卓电脑版怎么装系统,轻松实现... 你有没有想过,你的安卓电脑版突然间卡得像蜗牛一样,慢得让人抓狂?别急,今天就来教你怎么给它来个焕然一...
安卓系统有几种语音,揭秘多样化... 你知道吗?安卓系统里的语音功能可真是让人爱不释手呢!想象你只需要动动嘴,就能完成各种操作,是不是觉得...
扫码系统推荐安卓游戏,畅享指尖... 你有没有发现,最近手机里的游戏推荐越来越贴心了?没错,就是那个神奇的扫码系统!今天,就让我带你一探究...
手机系统安卓做的最好,探索最佳... 你有没有发现,现在手机市场上,安卓系统简直是要风得风,要雨得雨,简直是手机系统中的佼佼者!不信?那就...
安卓系统越拉越难用,越拉越难用... 你有没有发现,最近安卓系统越来越难用了?是不是每次打开手机,都感觉卡得要命,各种广告弹窗让人头疼不已...
卓安系统创始人,引领科技浪潮的... 你有没有想过,在这个信息爆炸的时代,谁才是那个站在风口浪尖,引领科技潮流的先锋?今天,我要带你认识一...
安卓10系统经常断网,安卓10... 最近是不是你也遇到了安卓10系统经常断网的问题?这可真是让人头疼啊!手机断网,就像失去了方向感的指南...
开发安卓系统用什么,从工具到实... 你有没有想过,为什么你的手机里装了那么多应用,却还是觉得不够用呢?其实,这一切都离不开一个强大的操作...
安卓系统如何双开抖音,安卓系统... 如何在安卓系统上双开抖音:让你的娱乐生活更加丰富多彩在数字化时代,手机已经成为我们生活中不可或缺的一...
安卓8.0系统内测地址,探索系... 你有没有听说最近安卓8.0系统内测的消息?这可是科技圈的大事啊!作为一个紧跟潮流的数码爱好者,我可是...
安卓系统可以账号同步吗,安卓系... 你有没有想过,你的安卓手机里的各种账户信息,比如微信、QQ、支付宝,能不能像变魔术一样,一键同步到另...
安卓系统的平板怎么下载,畅享应... 你有没有想过,拥有一款安卓系统的平板电脑,那感觉简直就像拥有了整个世界?想象随时随地都能畅游网络海洋...
win平板上装安卓系统咋样,开... 亲爱的读者们,你是否曾想过在Windows平板上体验安卓系统的魅力?想象那双熟悉的Windows界面...
给安卓车机写系统,安卓车机系统... 你有没有想过,你的安卓车机系统其实可以焕然一新?想象当你驾驶着爱车,车机界面流畅得像丝滑的巧克力,功...