- 转载请注明作者和出处:http://blog.csdn.net/u011475210
- 代码地址:https://github.com/WordZzzz/Note/tree/master/AtOffer
- 刷题平台:https://www.nowcoder.com/
- 题 库:剑指offer
- 编 者:WordZzzz
题目描述:
输入一棵二叉树,求该树的深度。从根结点到叶结点依次经过的结点(含根、叶结点)形成树的一条路径,最长路径的长度为树的深度。
解题思路:
DFS:题目很简单,用递归遍历只需一行。如果传入的树指针为空指针,则直接返回0;否则,递归调用TreeDepth,遍历左右子树并返回最大值。
BFS:层次遍历,需要使用队列。如果队列不为空,则在循环内不断的pop根节点、push左右子树,同时累加depth。
C++版代码实现:
递归:
1 | /* |
层序遍历:
1 | /* |
Python版代码实现:
递归:
1 | # -*- coding:utf-8 -*- |
层次遍历:
1 | # -*- coding:utf-8 -*- |
系列教程持续发布中,欢迎订阅、关注、收藏、评论、点赞哦~~( ̄▽ ̄~)~
完的汪(∪。∪)。。。zzz