题解 | #二叉树的最大深度#

二叉树的最大深度

http://www.nowcoder.com/practice/8a2b2bf6c19b4f23a9bdb9b233eefa73

DFS结题即可,实际上DFS和先序遍历是等价的,先序遍历是先读root,在读左右子树,DFS是先不停的去读左子树,然后不断返回到第一个有右子树的结点,读一下右子树,在返回,依次类推,两者是一样的。

class TreeNode:
    def __init__(self, x):
        self.val = x
        self.left = None
        self.right = None
#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param root TreeNode类 
# @return int整型
#
class Solution:
    def maxDepth1(self , root: TreeNode) -> int:
        # write code here
        # 进行一次先序遍历,返回最大深度
        self.max_depth = 0
        self.tra(root,1)
        return self.max_depth
    def tra(self,root,level):     
        if root==None:
            return 
        else:
            if level>self.max_depth:
                self.max_depth=level
            self.tra(root.left , level+1)
            self.tra(root.right , level+1)
    def maxDepth(self , root: TreeNode) -> int:
        self.max_depth = 0
        self.DFS(root,1)
        return self.max_depth
    def DFS(self,root,level):
        if root:
            if self.max_depth<level:
                self.max_depth=level
            self.DFS(root.left,level+1)
            self.DFS(root.right,level+1)

root = TreeNode(1)
root.left = TreeNode(2)
print(Solution().maxDepth(root))
全部评论

相关推荐

05-22 12:44
已编辑
门头沟学院 golang
点赞 评论 收藏
分享
05-26 10:24
门头沟学院 Java
qq乃乃好喝到咩噗茶:其实是对的,线上面试容易被人当野怪刷了
找工作时遇到的神仙HR
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-07 18:05
哈哈哈哈哈感觉朋友找工作的已经疯掉了,直接上图
码农索隆:真老板娘:“我嘞个去,这不我当年的套路吗
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务