合并二叉树

力扣题目链接(opens new window)

给定两个二叉树,想象当你将它们中的一个覆盖到另一个上时,两个二叉树的一些节点便会重叠。

你需要将他们合并为一个新的二叉树。合并的规则是如果两个节点重叠,那么将他们的值相加作为节点合并后的新值,否则不为 NULL 的节点将直接作为新二叉树的节点。

示例 1:

注意: 合并必须从两个树的根节点开始。

递归法

思路

这题的主要疑问就是:怎么同时遍历两个树?

其实解题模板已经给提示了,我们同时传入两个树的根节点即可

然后具体思路如下:

选择一颗树作为主树,另一颗往主树上合并(假设选择Tree1)

我们先判断Tree1、Tree2是否存在

如果Tree1不存在,那么合并结果直接为Tree2

如果Tree2不存在,那么合并结果直接为Tree1

如果都存在,则修改主树的值(即将Tree2节点的值与Tree1对应节点的值相加),返回主树的节点

然后调用递归函数,将Tree1的左子节点和Tree2的左子节点继续按上述方式处理。右子节点同理

代码
class Solution {
public:
TreeNode* mergeTrees(TreeNode* root1, TreeNode* root2) {
//确定结束条件
//判断两颗树是否都存在
if(root1 == NULL) return root2;
if(root2 == NULL) return root1; //都存在就合并(以root1为主树)
//定义一个新节点,不修改原树结构
TreeNode* root = new TreeNode(0);
root->val = root1->val + root2->val; //确定单层处理逻辑
//调用递归函数
root->left = mergeTrees(root1->left, root2->left);
root->right = mergeTrees(root1->right, root2->right);
return root;
}
};

注意,返回值一般出现在终止位置或者递归之后

迭代法

大体思想,参考判断对称二叉树的迭代法版本以及层序遍历

思路

说一下步骤吧

1、仍然是判断两棵树是否存在

2、创建队列,加入两棵树的根节点

3、遍历队列取出节点,设定一颗树为主树,将另一颗树的val叠加至主树上

4、分别判断此时root1、root2的左、右子节点是否存在,存在就加入队列

5、判断主树的左、右子节点是否为空,为空要用另一颗树的节点去补

代码
class Solution {//使用迭代法,层序遍历
public:
TreeNode* mergeTrees(TreeNode* root1, TreeNode* root2) {
//判断两棵树是否存在
if(root1 == NULL) return root2;
if(root2 == NULL) return root1;
//创建队列
queue<TreeNode*> que;
//将根节点加入队列(原教旨主义层序遍历的做法)
que.push(root1);
que.push(root2);
//遍历队列
while(!que.empty()){
//取出队列中的节点
TreeNode* node1 = que.front();
que.pop();
TreeNode* node2 = que.front();
que.pop(); //先将root2的值合并到root1
node1->val += node2->val; //判断root1、root2的左子节点是否都存在
if(node1->left != NULL && node2->left != NULL){
que.push(node1->left);
que.push(node2->left);
}
//判断root1、root2的右子节点是否都存在
if(node1->right != NULL && node2->right != NULL){
que.push(node1->right);
que.push(node2->right);
} //如果root1的左子节点不存在,root2的存在,将root2的值赋过去(注意,这里是以root1为主树)
if(node1->left == NULL && node2->left != NULL){
node1->left = node2->left;
} //如果root1的左子节点不存在,root2的存在,将root2的值赋过去
if(node1->right == NULL && node2->right != NULL){
node1->right = node2->right;
} }
return root1;//root1为主树
}
};

注意区分最后返回的节点,应该返回输入的根节点(并且是主树的根节点),而不是队列中取出的

【LeetCode二叉树#12】合并二叉树(巩固层序遍历)的更多相关文章

  1. 代码随想录算法训练营day20 | leetcode ● 654.最大二叉树 ● 617.合并二叉树 ● 700.二叉搜索树中的搜索 ● 98.验证二叉搜索树

    LeetCode 654.最大二叉树 分析1.0 if(start == end) return节点索引 locateMaxNode(arr,start,end) new root = 最大索引对应节 ...

  2. 【LeetCode】 617. 合并二叉树

    题目 给定两个二叉树,想象当你将它们中的一个覆盖到另一个上时,两个二叉树的一些节点便会重叠. 你需要将他们合并为一个新的二叉树.合并的规则是如果两个节点重叠,那么将他们的值相加作为节点合并后的新值,否 ...

  3. 手写二叉树-先序构造(泛型)-层序遍历(Java版)

    如题 先序构造 数据类型使用了泛型,在后续的更改中,更换数据类型只需要少许的变更代码 层序遍历 利用Node类的level属性 所有属性的权限全为public ,为了方便先这么写吧,建议还是用priv ...

  4. 【剑指offer】不分行从上到下打印二叉树,C++实现(层序遍历)

    原创文章,转载请注明出处! 本题牛客网地址 博客文章索引地址 博客文章中代码的github地址 1.题目 从上往下打印出二叉树的每个节点,同层节点从左至右打印.例如: 图  不分行从上往下按层打印二叉 ...

  5. 二叉树(前序,中序,后序,层序)遍历递归与循环的python实现

    二叉树的遍历是在面试使比较常见的项目了.对于二叉树的前中后层序遍历,每种遍历都可以递归和循环两种实现方法,且每种遍历的递归实现都比循环实现要简洁.下面做一个小结. 一.中序遍历 前中后序三种遍历方法对 ...

  6. [LeetCode] Binary Tree Level Order Traversal II 二叉树层序遍历之二

    Given a binary tree, return the bottom-up level order traversal of its nodes' values. (ie, from left ...

  7. [LeetCode] Binary Tree Zigzag Level Order Traversal 二叉树的之字形层序遍历

    Given a binary tree, return the zigzag level order traversal of its nodes' values. (ie, from left to ...

  8. [LeetCode] Binary Tree Level Order Traversal 二叉树层序遍历

    Given a binary tree, return the level order traversal of its nodes' values. (ie, from left to right, ...

  9. [LeetCode] 103. Binary Tree Zigzag Level Order Traversal 二叉树的之字形层序遍历

    Given a binary tree, return the zigzag level order traversal of its nodes' values. (ie, from left to ...

  10. [LeetCode] 102. Binary Tree Level Order Traversal 二叉树层序遍历

    Given a binary tree, return the level order traversal of its nodes' values. (ie, from left to right, ...

随机推荐

  1. [转帖]查看x86 cpu睿频命令

    查看cpu是否开启睿频,offline掉一些cpu核心后,查看cpu睿频是否升高? turbostat统计X86 处理器的频率.空闲状态.电源状态.温度等状态等 [root@rootbird~]# t ...

  2. [转帖]关于F5负载均衡你认识多少?

    https://www.cnblogs.com/xiexun/p/10718348.html 网络负载均衡(load balance),就是将负载(工作任务)进行平衡.分摊到多个操作单元上进行执行,例 ...

  3. Beyond Compare 的比较以及导出的简单设置方法

    最近需要对文件进行对比 但是发现对比的工作量比较难搞. 用到了beyond compare 的工具 感觉挺好用的 但是需要注意事项比较多这里记录一下 1.  session setting 里面进行设 ...

  4. Semantic Kernel 通过 LocalAI 集成本地模型

    本文是基于 LLama 2是由Meta 开源的大语言模型,通过LocalAI 来集成LLama2 来演示Semantic kernel(简称SK) 和 本地大模型的集成示例. SK 可以支持各种大模型 ...

  5. 从一次CPU打满到ReDos攻击和防范

    作者:京东物流 刘海茂 近期碰到一起值班报警事件,web 应用服务器 CPU 消耗打到 99%,排查后发现是因为 ReDoS 导致了服务器发生了资源被耗尽.访问系统缓慢的问题,通过排查过程从而分享下 ...

  6. 【发现一个小问题】坑爹的官方日志库`golang.org/x/exp/slog`,凭啥不让我设置debug级别日志

    作者:张富春(ahfuzhang),转载时请注明作者和引用链接,谢谢! cnblogs博客 zhihu Github 公众号:一本正经的瞎扯 一个代码使用了官方的日志库"golang.org ...

  7. 微信小程序-常用弹窗

    官方文档:https://developers.weixin.qq.com/miniprogram/dev/api/ui/interaction/wx.showToast.html showToast ...

  8. 因为命名被diss无数次。简单聊聊编程最头疼的事情之一:命名

    本文已经收录进我的 80K+ Star 的 Java 开源项目 JavaGuide:https://github.com/Snailclimb/JavaGuide (「Java学习+面试指南」一份涵盖 ...

  9. Linux 统计Web服务日志命令

    本人在Linux运维中收集的一些通用的统计,Apache/Nginx服务器日志的命令组合. Apache日志统计 # 列出当天访问次数最多的IP命令 [root@lyshark.cnblogs.com ...

  10. 路由react-router-dom的使用

    react-router-dom路由简介 现代的前端页面大多是SPA(单页面应用程序), 也就是只有一个HTML页面的程序,这样用户体验好,服务器压力小,所以更受欢迎.路由是使用单页面来管理原来多页面 ...