Google 面试题 | 找二叉树最底层最左边的节点

1,348 阅读1分钟

专栏 | 九章算法

网址 | http://www.jiuzhang.com

题目描述

给一棵二叉树,求出该二叉树最底层最左边的节点。

样例:

image
默认标题_自定义px_2018.01.31.png

算法分析

这题有2个做法,一是宽度优先搜索,用每层的第一个节点来更新答案。二是深度优先搜索,当遇到一个节点的深度大于目前维护的最大深度时用这个节点来更新答案。

  1. 使用宽度优先搜索bfs,用每层的第一个节点更新Ans。时间复杂度O(n)。

  2. 使用深度优先搜索dfs,当我们第一次访问一个深度为depth的节点x(之前只访问过深度小于depth的节点)时,x一定是depth深度的最左节点,用这个节点更新Ans。即我们维护一个最大深度,当遍历到一个点的深度大于最大深度时,用这个节点来更新答案,并更新最大深度即可。时间复杂度O(n)。

参考程序

image

www.jiuzhang.com/solution/fi…

面试官角度分析

这道题是一道简单难度题,考点是基础数据结构二叉树和在二叉树中的搜索,用bfs和dfs均可。给出正确算法即可达到hire。lintcode相关问题

image
QQ截图20180131175409.png

www.lintcode.com/zh-cn/probl…

欢迎关注我的微信公众号:九章算法(ninechapter)。
精英程序员交流社区,定期发布面试题、面试技巧、求职信息等
2d09fefd332a1a68bb1c.jpeg