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

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

描述:

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

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

示例 1:

在这里插入图片描述
注意: 合并必须从两个树的根节点开始。

代码如下:

# Definition for a binary tree node.# class TreeNode:#     def __init__(self, x):#         self.val = x#         self.left = None#         self.right = Noneclass Solution:    def mergeTrees(self, t1, t2):        """        :type t1: TreeNode        :type t2: TreeNode        :rtype: TreeNode        """        if t1 and not t2:            return t1        if t2 and not t1:            return t2        if t1 and t2:            t1.val+=t2.val            t1.left = self.mergeTrees(t1.left, t2.left)            t1.right = self.mergeTrees(t1.right, t2.right)            return t1

分析:

对于每一个新的点的值,我们需要做的就是把两个树中的同样位置的点的值相加。然后用递归来继续代入mergeTrees,左边的点,就代入同样位置两个点的左边。右边的点就代入同样位置的两个点的右边。

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

你可能感兴趣的文章
c++写时拷贝1
查看>>
Linux网络编程---I/O复用模型之poll
查看>>
Java NIO详解
查看>>
在JS中 onclick="save();return false;"return false是
查看>>
idea 有时提示找不到类或者符号
查看>>
matplotlib.pyplot.plot()参数详解
查看>>
MFC矩阵运算
查看>>
ubuntu 安装mysql
查看>>
c# 计算器
查看>>
C# 简单的矩阵运算
查看>>
gcc 常用选项详解
查看>>
c++输出文件流ofstream用法详解
查看>>
firewalld的基本使用
查看>>
Linux下SVN客户端使用教程
查看>>
Linux分区方案
查看>>
nc 命令详解
查看>>
如何使用 systemd 中的定时器
查看>>
git命令速查表
查看>>
linux进程监控和自动重启的简单实现
查看>>
OpenFeign学习(三):OpenFeign配置生成代理对象
查看>>