LeetCode-求二叉树的最大深度
题目详情

题目链接:二叉树的最大深度
一、解题思路
通过递归的方式,不断遍历其树的每一个节点。然后判断当前节点是否为空,不为空高度加 1,同时遍历当前节点的子节点,然后比较左右两节点的高度,返回最大的节点高度。反之则直接返回上一节点的高度。
二、解题步骤
1.详细步骤
- 判断当前节点是否为空
- 如果为空,直接返回上一节点的高度
- 反之高度加 1 ,并执行下一步
- 继续递归调用该函数,将其节点设置为当前节点,同时高度设置为当前节点的高度。并设置变量用于获取函数的返回值。
- 比较左右两个节点函数返回值,取其最大值。
2. 代码
代码如下:
1 | class Solution { |
三、总结
这里面主要用到了递归的思想。递归在与树有关的很多的题目都可以使用该思想。通过该思想可以很大程度上简化代码。但是也不是没有缺点,如果递归次数过多的话,可能会造成堆栈溢出。
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 无♥部落阁!
评论




