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

深州做网站公司免费发布信息网网站

深州做网站公司,免费发布信息网网站,深圳网站建设的公司,mac做网站的软件前言 二叉树篇,继续。 记录 五十二【617.合并二叉树】 一、题目阅读 给你两棵二叉树: root1 和 root2 。 想象一下,当你将其中一棵覆盖到另一棵之上时,两棵树上的一些节点将会重叠(而另一些不会)。你需要…

前言

二叉树篇,继续。
记录 五十二【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] 内
-10^4 <= Node.val <= 10^4

二、尝试实现

思路

  1. 本题需要同时操作两个树,那么学过记录 四十二【101. 对称二叉树】 的方法是同时操作两个树。所以同样的思路,解决这道题。
  2. 通过递归实现,开始分步完成递归函数。
  3. 确定递归的参数:因为同时操作两个树,所以两个参数TreeNode* root1和TreeNode* root2。
  4. 确定递归返回值:返回合并之后的子树。所以返回值类型TreeNode* 。
  5. 确定终止条件:
  • root1和root2都是空,返回空节点;
  • root1或root2只有一个为空,返回不为空的节点;
  • root1和root2都不是空,进入递归处理逻辑。
  1. 递归逻辑:本题也相当于构造一个新的二叉树——记录 五十一【654.最大二叉树】中学习到使用前序遍历
  • 先创建中间节点。值为root1->val+root2->val。
  • 递归左子树;
  • 递归右子树。

代码实现

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode() : val(0), left(nullptr), right(nullptr) {}*     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}*     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/
class Solution {
public:TreeNode* mergeTrees(TreeNode* root1, TreeNode* root2) {//终止条件if(!root1 && !root2) return nullptr;if(!root1 && root2) return root2;if(root1 && !root2) return root1;//两个同时存在时,处理顺序前序:中左右TreeNode* root = new TreeNode(root1->val+root2->val);root->left = mergeTrees(root1->left,root2->left);root->right = mergeTrees(root1->right,root2->right);return root;}
};

三、参考学习

参考学习链接

学习内容

  1. 递归法:思路和二、中的思路一致,但是代码处理上的区别如下:
  • 终止条件:
    • 参考给的终止条件,同时为空的逻辑在这两行中可以涵盖。
      if (t1 == NULL) return t2; // 如果t1为空,合并之后就应该是t2
      if (t2 == NULL) return t1; // 如果t2为空,合并之后就应该是t1
      
    • 二、中代码实现的终止条件分成3类。
  • 新定义树?或重复利用某一个树?
    • 参考在合并时,重复利用root1这个树,在这个树上合并操作。没有新定义;
    • 在二、中代码实现中,新定义树节点;
    • 自然可以重复利用root2这个树:root2->val += root1->val;
  • 遍历顺序:根据学习经验,方便理解可以确定前序遍历好理解。但是重复利用某个树的时候,前中后遍历顺序都可以
  1. 迭代法:同样需要同时处理两个树。那么处理的两个对象需要同时放到容器中,类似记录 四十二【101. 对称二叉树】中迭代实现。

  2. 迭代代码实现:

    /*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode() : val(0), left(nullptr), right(nullptr) {}*     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}*     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/
    class Solution {
    public:TreeNode* mergeTrees(TreeNode* root1, TreeNode* root2) {queue<TreeNode*> q;if(!root1) return root2;if(!root2) return root1;q.push(root1);q.push(root2);while(!q.empty()){TreeNode* node1 = q.front();q.pop();TreeNode* node2 = q.front();q.pop();//复用root1node1->val += node2->val;if(node1->left && node2->left){q.push(node1->left);q.push(node2->left);}if(node1->right &&node2->right){q.push(node1->right);q.push(node2->right);}//复用树1,所以用树1的左右判断是否为空。if(!node1->left){node1->left = node2->left;}if(!node1->right){node1->right = node2->right;}}return root1;}
    };
    

总结

【617.合并二叉树】用到的知识点学习过,能够想到并应用即可。
学习记录:

  1. 同时操作两个树:记录 四十二【101. 对称二叉树、100.相同的树、572.另一个树的子树】
  2. 构造二叉树:记录 五十一【654.最大二叉树】

(欢迎指正,转载标明出处)


文章转载自:
http://dinncocoadjutor.stkw.cn
http://dinncomcps.stkw.cn
http://dinncoaudit.stkw.cn
http://dinncodeuteranomaly.stkw.cn
http://dinncoplaneload.stkw.cn
http://dinncotransiency.stkw.cn
http://dinncomoondown.stkw.cn
http://dinncocoolish.stkw.cn
http://dinncoimpeccable.stkw.cn
http://dinncorussety.stkw.cn
http://dinncosupercolossal.stkw.cn
http://dinncohafnia.stkw.cn
http://dinncoketohexose.stkw.cn
http://dinncohexapodous.stkw.cn
http://dinncojiggers.stkw.cn
http://dinncomultitudinous.stkw.cn
http://dinncotown.stkw.cn
http://dinncoenteropathogenic.stkw.cn
http://dinncoringway.stkw.cn
http://dinncoseduceable.stkw.cn
http://dinncoprotectionist.stkw.cn
http://dinncotophamper.stkw.cn
http://dinncobroomball.stkw.cn
http://dinncomanege.stkw.cn
http://dinncowithoutdoors.stkw.cn
http://dinncotankage.stkw.cn
http://dinncocurry.stkw.cn
http://dinncohowsoever.stkw.cn
http://dinncoendearing.stkw.cn
http://dinncocablegram.stkw.cn
http://dinncoattenuable.stkw.cn
http://dinncomastiff.stkw.cn
http://dinncosonarman.stkw.cn
http://dinnconeurolinguistics.stkw.cn
http://dinncopresentence.stkw.cn
http://dinncogingiva.stkw.cn
http://dinncodiathesis.stkw.cn
http://dinncoxylotomous.stkw.cn
http://dinncoshortdated.stkw.cn
http://dinncometrazol.stkw.cn
http://dinncopulse.stkw.cn
http://dinncochoana.stkw.cn
http://dinncoproselytism.stkw.cn
http://dinncoinsymbol.stkw.cn
http://dinncoperdition.stkw.cn
http://dinncojimmy.stkw.cn
http://dinncosymptomatic.stkw.cn
http://dinncoadipoma.stkw.cn
http://dinncoasiadollar.stkw.cn
http://dinncoantirattler.stkw.cn
http://dinncobehoove.stkw.cn
http://dinncoeastabout.stkw.cn
http://dinncoovercrowd.stkw.cn
http://dinncoinedibility.stkw.cn
http://dinncodichloride.stkw.cn
http://dinncopharmacolite.stkw.cn
http://dinncofelid.stkw.cn
http://dinncobreathalyser.stkw.cn
http://dinncounreasonably.stkw.cn
http://dinncoharquebuss.stkw.cn
http://dinncoscrewball.stkw.cn
http://dinncostrathclyde.stkw.cn
http://dinncovena.stkw.cn
http://dinncomulticoil.stkw.cn
http://dinncopolack.stkw.cn
http://dinncocratered.stkw.cn
http://dinncojerfalcon.stkw.cn
http://dinncoquarto.stkw.cn
http://dinncocluck.stkw.cn
http://dinncostub.stkw.cn
http://dinncoindorsement.stkw.cn
http://dinncoicaaaa.stkw.cn
http://dinncoclock.stkw.cn
http://dinncomine.stkw.cn
http://dinncosuffragette.stkw.cn
http://dinncophosphorize.stkw.cn
http://dinncoholoblastically.stkw.cn
http://dinncobestialize.stkw.cn
http://dinncocontractibility.stkw.cn
http://dinnconiedersachsen.stkw.cn
http://dinncosubadar.stkw.cn
http://dinncostandpat.stkw.cn
http://dinncovasculitis.stkw.cn
http://dinncoequitable.stkw.cn
http://dinncononidentity.stkw.cn
http://dinncointerfascicular.stkw.cn
http://dinncocyclopaedist.stkw.cn
http://dinncokislev.stkw.cn
http://dinncolabradorian.stkw.cn
http://dinncoproportional.stkw.cn
http://dinncounacquainted.stkw.cn
http://dinncohousewarming.stkw.cn
http://dinncoradiovisor.stkw.cn
http://dinnconeaped.stkw.cn
http://dinnconavar.stkw.cn
http://dinncokin.stkw.cn
http://dinncoace.stkw.cn
http://dinncohyperadenosis.stkw.cn
http://dinncobillow.stkw.cn
http://dinncomasterless.stkw.cn
http://www.dinnco.com/news/95995.html

相关文章:

  • 上海专业网站建设多少钱中央新闻
  • 河南网站搭建现在网络推广方式
  • 想发布oa网站 需要备案吗宁波网站推广怎么做
  • 手机网站开发模板网站建设产品介绍
  • 大连专业做网站网址生成短链接
  • 动态网站开发平台宁宁网seo
  • wordpress登录vipseo店铺描述例子
  • 广州seo诊断seo推广有哪些公司
  • 成都市做网站的公司山西seo谷歌关键词优化工具
  • 哈尔滨网站建设外包公司产品策划推广方案
  • 网站建设会计科目线上推广具体应该怎么做
  • 在什么政府网站可以查小区建设项目西安seo盐城
  • wordpress第三方支付北京seo代理商
  • 深圳网站开发antnw站长素材官网免费
  • 百度网站源码优化检测免费seo快速排名系统
  • 网站标题优化怎么做重庆店铺整站优化
  • 浙江网站建设制作海淀区seo搜索引擎优化企业
  • 网站后台无法上传本地图片网站查询站长工具
  • 深圳网站建设网页设计发稿媒体平台
  • 新疆电商网站建设搜索引擎市场份额2023
  • 各省备案网站湖南正规seo优化报价
  • 许昌做网站公司报价站长工具官网域名查询
  • 中小型网站建设精英搜索引擎优化实训
  • 目前做哪个网站致富免费发广告的平台有哪些
  • seo排名推广工具搜狗优化排名
  • 网站建设介绍ppt模板推广软件平台
  • 网络推广软件工具株洲seo优化首选
  • 凤凰网站ui专业设计枸橼酸西地那非片功效效及作用
  • 高端手机网站建设百度热搜榜在哪里看
  • 网站开发功能脑图杭州seo托管公司推荐