前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >110. 平衡二叉树

110. 平衡二叉树

作者头像
程序员小王
发布2018-07-25 10:40:44
4380
发布2018-07-25 10:40:44
举报
文章被收录于专栏:架构说架构说

110. 平衡二叉树

给定一个二叉树,判断它是否是高度平衡的二叉树。

本题中,一棵高度平衡二叉树定义为:

一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过1。

示例 1:

给定二叉树 [3,9,20,null,null,15,7]

代码语言:javascript
复制
    3
   / \
  9  20
    /  \
   15   7

返回 true 。 示例 2:

给定二叉树 [1,2,2,3,3,null,null,4,4]

代码语言:javascript
复制
       1
      / \
     2   2
    / \
   3   3
  / \
 4   4

返回 false

题目难度: 简单

第一版本:

根据定义

1 遍历 treeo o(n)

2 然后计算每个节点的深度 o(n)

3 如果当前节点为不满足定义 false 整个tree就是不平衡的二叉树

time:o(n*2)

正如西部世界 故事线有2个故事性

世界分为三条线,两实一虚: 1. 当前时间线: 黑帽威廉时间线,凡是有黑帽威廉的都在当前时间 2. 历史时间线:白帽威廉时间线 (35年前),凡是有白帽威廉的都在历史时间,属于回忆 3. 虚拟时间线: 女主脑海中的闪回,脑补画面,与时间没直接关系,可在多个时间线跳跃,也可以是完全脑补的画面。 当女主是穿蓝色的连衣裙、自言自语时属于这条虚拟时间线。

求平衡二叉树2个故事

  • 一个是遍历tree判断是否平衡的二叉树
  • 一个是遍历tree求深度

第二版本:

golang 通过函数多个参数的返回值 返回从下到上传递的数据

测试异常

代码语言:javascript
复制
 /递归判断是否平衡二叉树 root left right 节点都平衡
代码语言:javascript
复制
 bRoot := math.Abs(float64(dLeft)-float64(dRight)) >1   
代码语言:javascript
复制
应该是求判断是否符合条件
代码语言:javascript
复制

c++ 通过引用传递 返回从下到上传递的数据

总结:

体会到了 c++ 引用传参 和golang 返回多个参数各种优点


本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-05-09,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Offer多多 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 110. 平衡二叉树
    • 第一版本:
      • 第二版本:
        • golang 通过函数多个参数的返回值 返回从下到上传递的数据
        • c++ 通过引用传递 返回从下到上传递的数据
      • 总结:
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档