【LeetCode二叉树#12】合并二叉树(巩固层序遍历)
合并二叉树
给定两个二叉树,想象当你将它们中的一个覆盖到另一个上时,两个二叉树的一些节点便会重叠。
你需要将他们合并为一个新的二叉树。合并的规则是如果两个节点重叠,那么将他们的值相加作为节点合并后的新值,否则不为 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】合并二叉树(巩固层序遍历)的更多相关文章
- 代码随想录算法训练营day20 | leetcode ● 654.最大二叉树 ● 617.合并二叉树 ● 700.二叉搜索树中的搜索 ● 98.验证二叉搜索树
LeetCode 654.最大二叉树 分析1.0 if(start == end) return节点索引 locateMaxNode(arr,start,end) new root = 最大索引对应节 ...
- 【LeetCode】 617. 合并二叉树
题目 给定两个二叉树,想象当你将它们中的一个覆盖到另一个上时,两个二叉树的一些节点便会重叠. 你需要将他们合并为一个新的二叉树.合并的规则是如果两个节点重叠,那么将他们的值相加作为节点合并后的新值,否 ...
- 手写二叉树-先序构造(泛型)-层序遍历(Java版)
如题 先序构造 数据类型使用了泛型,在后续的更改中,更换数据类型只需要少许的变更代码 层序遍历 利用Node类的level属性 所有属性的权限全为public ,为了方便先这么写吧,建议还是用priv ...
- 【剑指offer】不分行从上到下打印二叉树,C++实现(层序遍历)
原创文章,转载请注明出处! 本题牛客网地址 博客文章索引地址 博客文章中代码的github地址 1.题目 从上往下打印出二叉树的每个节点,同层节点从左至右打印.例如: 图 不分行从上往下按层打印二叉 ...
- 二叉树(前序,中序,后序,层序)遍历递归与循环的python实现
二叉树的遍历是在面试使比较常见的项目了.对于二叉树的前中后层序遍历,每种遍历都可以递归和循环两种实现方法,且每种遍历的递归实现都比循环实现要简洁.下面做一个小结. 一.中序遍历 前中后序三种遍历方法对 ...
- [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 ...
- [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 ...
- [LeetCode] Binary Tree Level Order Traversal 二叉树层序遍历
Given a binary tree, return the level order traversal of its nodes' values. (ie, from left to right, ...
- [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 ...
- [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, ...
随机推荐
- [转帖]查看x86 cpu睿频命令
查看cpu是否开启睿频,offline掉一些cpu核心后,查看cpu睿频是否升高? turbostat统计X86 处理器的频率.空闲状态.电源状态.温度等状态等 [root@rootbird~]# t ...
- [转帖]关于F5负载均衡你认识多少?
https://www.cnblogs.com/xiexun/p/10718348.html 网络负载均衡(load balance),就是将负载(工作任务)进行平衡.分摊到多个操作单元上进行执行,例 ...
- Beyond Compare 的比较以及导出的简单设置方法
最近需要对文件进行对比 但是发现对比的工作量比较难搞. 用到了beyond compare 的工具 感觉挺好用的 但是需要注意事项比较多这里记录一下 1. session setting 里面进行设 ...
- Semantic Kernel 通过 LocalAI 集成本地模型
本文是基于 LLama 2是由Meta 开源的大语言模型,通过LocalAI 来集成LLama2 来演示Semantic kernel(简称SK) 和 本地大模型的集成示例. SK 可以支持各种大模型 ...
- 从一次CPU打满到ReDos攻击和防范
作者:京东物流 刘海茂 近期碰到一起值班报警事件,web 应用服务器 CPU 消耗打到 99%,排查后发现是因为 ReDoS 导致了服务器发生了资源被耗尽.访问系统缓慢的问题,通过排查过程从而分享下 ...
- 【发现一个小问题】坑爹的官方日志库`golang.org/x/exp/slog`,凭啥不让我设置debug级别日志
作者:张富春(ahfuzhang),转载时请注明作者和引用链接,谢谢! cnblogs博客 zhihu Github 公众号:一本正经的瞎扯 一个代码使用了官方的日志库"golang.org ...
- 微信小程序-常用弹窗
官方文档:https://developers.weixin.qq.com/miniprogram/dev/api/ui/interaction/wx.showToast.html showToast ...
- 因为命名被diss无数次。简单聊聊编程最头疼的事情之一:命名
本文已经收录进我的 80K+ Star 的 Java 开源项目 JavaGuide:https://github.com/Snailclimb/JavaGuide (「Java学习+面试指南」一份涵盖 ...
- Linux 统计Web服务日志命令
本人在Linux运维中收集的一些通用的统计,Apache/Nginx服务器日志的命令组合. Apache日志统计 # 列出当天访问次数最多的IP命令 [root@lyshark.cnblogs.com ...
- 路由react-router-dom的使用
react-router-dom路由简介 现代的前端页面大多是SPA(单页面应用程序), 也就是只有一个HTML页面的程序,这样用户体验好,服务器压力小,所以更受欢迎.路由是使用单页面来管理原来多页面 ...