作者: 负雪明烛
id: fuxuemingzhu
个人博客: http://fuxuemingzhu.cn/


题目地址:https://leetcode.com/problems/merge-two-binary-trees/description/

题目描述

Given two binary trees and imagine that when you put one of them to cover the other, some nodes of the two trees are overlapped while the others are not.

You need to merge them into a new binary tree. The merge rule is that if two nodes overlap, then sum node values up as the new value of the merged node. Otherwise, the NOT null node will be used as the node of new tree.

Example 1:

Input:
Tree 1 Tree 2
1 2
/ \ / \
3 2 1 3
/ \ \
5 4 7
Output:
Merged tree:
3
/ \
4 5
/ \ \
5 4 7

题目大意

将两个二叉树进行merge操作。操作方式是把两个树进行重叠,如果重叠部分都有值,那么这个新节点是他们的值的和;如果重叠部分没有值,那么新的节点就是他们两个当中不为空的节点。

解题方法

递归

如果两个树都有节点的话就把两个相加,左右孩子为两者的左右孩子。

否则选不是空的节点当做子节点。

时间复杂度是O(N1+N2),空间复杂度O(N)。N = t1 的 t2交集。

class Solution:
def mergeTrees(self, t1, t2):
"""
:type t1: TreeNode
:type t2: TreeNode
:rtype: TreeNode
"""
if t1 and t2:
newT = TreeNode(t1.val + t2.val)
newT.left = self.mergeTrees(t1.left, t2.left)
newT.right = self.mergeTrees(t1.right, t2.right)
return newT
else:
return t1 or t2

也可以换一种写法,没有任何区别:

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

日期

2018 年 1 月 13 日
2018 年 11 月 3 日 —— 雾霾的周六

最新文章

  1. System Sounds: Alerts and Sound Effects
  2. Zigzag convert
  3. HDU 4287 Intelligent IME hash
  4. Fast scroller styles
  5. 《转》GDB中应该知道的几个调试方法
  6. 雄踞AppStore榜首的游戏<别踩到白块儿>源码分析和下载(一)
  7. MyEclipse保存文件时 自动格式化代码! 不包括文档注释
  8. BestCoder Round #36 [B] Gunner
  9. Python 入门教程 9 ---- A Day at the Supermarket
  10. myeclipse将java项目转换成web项目,导出war包
  11. JavaScript八张思维导图—基本语句
  12. 【渗透攻防】千变万化的WebShell
  13. js 常用正则表达式
  14. SQL Agent Job 报“Access to the remote server is denied because the current security context is not trusted”
  15. VMware设置cpu虚拟化,intel VT-x
  16. 关于OSG+QT+VS版本的问题
  17. symfony学习笔记2—纯的PHP代码和symfony的区别
  18. PAT 1043 Is It a Binary Search Tree[二叉树][难]
  19. windows下使用redis
  20. async函数结合promise的小案例

热门文章

  1. mysql_sql查性能语句
  2. Linux关机/重启/用户切换/注销
  3. 关于SQL中Union和Join的用法
  4. 关于写SpringBoot+Mybatisplus+Shiro项目的经验分享三:问题2
  5. adhere, adjust, adjacent
  6. 大数据学习day20-----spark03-----RDD编程实战案例(1 计算订单分类成交金额,2 将订单信息关联分类信息,并将这些数据存入Hbase中,3 使用Spark读取日志文件,根据Ip地址,查询地址对应的位置信息
  7. zabbix之模板制作(memcache redis)
  8. OSGI 生命周期
  9. 阿里云esc 安装 mysql5.7.27
  10. mybtis入门