美文网首页
LeetCode104-二叉树的最大深度(动态规划,DFS,BF

LeetCode104-二叉树的最大深度(动态规划,DFS,BF

作者: JunfengsBlog | 来源:发表于2020-01-30 09:10 被阅读0次
# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None

class Solution:
    def maxDepth(self, root: TreeNode) -> int:
        # 递归求解树的高度
        if not root:
            return 0
        if not root.left and not root.right:
            return 1
        return max(self.maxDepth(root.left), self.maxDepth(root.right)) + 1
------------------------------------------------------------------------------------------------
        # 迭代求解树的高度
        if not root:
            return 0
        treeHeight = 0
        queue = [root]
        while queue:
            next_queue = []
            treeHeight = treeHeight + 1
            for node in queue:
                if not node:
                    continue
                if node.left:
                    next_queue.append(node.left)
                if node.right:
                    next_queue.append(node.right)
            queue = next_queue
        return treeHeight


上面的第一种方法本质上应该是一种动态规划的解法,第二种法中迭代法实际上的BFS的方式求解树高,下面再给出第三种DFS求解树高的方法:

class Solution:
    def maxDepth(self, root: TreeNode) -> int:
        self.levelHeight = 0
        self.dfs(root, 1)
        return self.levelHeight
        
    def dfs(self, root, level):
        if not root:
            return 0
        if self.levelHeight < level:
            self.levelHeight += 1
        self.dfs(root.left, level + 1)
        self.dfs(root.right, level + 1)

相关文章

  • LeetCode104-二叉树的最大深度(动态规划,DFS,BF

    上面的第一种方法本质上应该是一种动态规划的解法,第二种法中迭代法实际上的BFS的方式求解树高,下面再给出第三种DF...

  • 二叉树

    深度优先遍历 递归 DFS 广度优先遍历 递归BFS 二叉树的最大最小深度 判断二叉树是否中轴对称

  • LeetCode 第559题:N叉树的最大深度

    1、前言 2、思路 此题可以用 DFS 跟 BFS 来做。N 叉树的最大深度跟二叉树的最大深度求解很类似,代码完全...

  • 二叉树

    一、目录 DFS 144.二叉树的前序遍历 145.二叉树的后序遍历(hard) 104.二叉树的最大深度 111...

  • 树相关的题目

    二叉树的构建:左子树,跟节点,右子树 二叉树的遍历:前序,中序,后序,DFS,BFS,所有路径 二叉树深度:最大深...

  • 算法

    算法应用BFS广度优先搜索DFS深度优先搜索回溯法(DFS+剪枝)部分和问题分治法快速排序、归并排序动态规划背包问...

  • LeetCode中的题目的特点

    解这些题都是有套路的,不是用递归(深度优先DFS,广度优先BFS),就是要用动态规划(Dynamic Progra...

  • 动态规划,dfs

    鸡蛋掉落问题 你将获得 K 个鸡蛋,并可以使用一栋从 1 到 N 共有 N 层楼的建筑。每个蛋的功能都是一样的,如...

  • 二叉树面试题基本问题

    二叉树的最大深度与最小深度 二叉树的最大深度 最大深度是指二叉树根节点到该树叶子节点的最大路径长度。而最小深度自然...

  • NYOJ 90 整数划分

    法一:递归 法二:动态规划 法三:DFS

网友评论

      本文标题:LeetCode104-二叉树的最大深度(动态规划,DFS,BF

      本文链接:https://www.haomeiwen.com/subject/yaqithtx.html