题解 | #合并二叉树#

合并二叉树

https://www.nowcoder.com/practice/7298353c24cc42e3bd5f0e0bd3d1d759

# class TreeNode:
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None
#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param t1 TreeNode类 
# @param t2 TreeNode类 
# @return TreeNode类
#
class Solution:
    def mergeTrees(self , t1: TreeNode, t2: TreeNode) -> TreeNode:
        # write code here
        if t1 is None:
            return t2
        if t2 is None:
            return t1

        head = TreeNode(t1.val+t2.val)
        head.left = self.mergeTrees(t1.left, t2.left)
        head.right = self.mergeTrees(t1.right, t2.right)
        return head

步骤:

  • 判断t1与t2是否为空,若为空则用另一个代替。
  • 依据前序遍历,优先访问根节点,将两个根点的值相加创建到新树中。
  • 两棵树依次同步进入左子树和右子树。

复杂度:

  • 时间复杂度:O(min(n,m)),m和n分别为两棵树的节点树,当一个树访问完时,直接连接上另一个树的节点,故只访问了小树的节点数。
  • 空间复杂度:O(min(n,m)),递归栈深度只访问了小树的节点数。
全部评论

相关推荐

09-17 19:25
已编辑
太原理工大学 游戏测试
叁六玖:公司名发我,我要这个HR带我打瓦
我的秋招日记
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务