博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
合并二叉树
阅读量:4166 次
发布时间:2019-05-26

本文共 532 字,大约阅读时间需要 1 分钟。

一、题目:

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

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

在这里插入图片描述

二、解题思路:

依据题目,两个树合并,也就是各个节点对应相加,如果一个节点为空的话就返回另一棵树的该节点。

三、代码和结果:

class Solution {
public: TreeNode* mergeTrees(TreeNode* root1, TreeNode* root2) {
if(root1==0) return root2; if(root2==0) return root1; auto m =new TreeNode(root1->val+root2->val); m->left =mergeTrees(root1->left,root2->left); m->right =mergeTrees(root1->right,root2->right); return m; } };

结果:

在这里插入图片描述

转载地址:http://gnexi.baihongyu.com/

你可能感兴趣的文章
Node.js中运行JavaScript代码
查看>>
5月英语总结--I will do it well.
查看>>
认识JS
查看>>
Google浏览器--翻译一定要“出去”吗?
查看>>
bash:ifconfig:未找到命令
查看>>
送给毕业的歌
查看>>
嵌入式100题(017):malloc的底层实现
查看>>
嵌入式100题(018):在1G内存的计算机中能否malloc(1.2G)?为什么?
查看>>
嵌入式100题(019):指针与引用的相同和区别;如何相互转换?
查看>>
嵌入式100题(040):什么是三次握手
查看>>
嵌入式100题(037):Http1.1和Http1.0的区别
查看>>
嵌入式100题(038):HTTPS与HTTP的一些区别
查看>>
嵌入式100题(042):为什么服务端易受到SYN攻击?
查看>>
嵌入式100题(043):什么是四次挥手
查看>>
嵌入式100题(044):为什么客户端最后还要等待2MSL?
查看>>
嵌入式100题(045):为什么建立连接是三次握手,关闭连接确是四次挥手呢?...
查看>>
嵌入式100题(028):static的用法(定义和用途)
查看>>
嵌入式100题(027):char和int之间的转换
查看>>
嵌入式100题(029):const常量和#define的区别(编译阶段、安全性、内存占用等)...
查看>>
嵌入式100题(030):volatile作用和用法
查看>>