Skip to content

Latest commit

 

History

History
63 lines (57 loc) · 1.58 KB

55-I.二叉树的深度.md

File metadata and controls

63 lines (57 loc) · 1.58 KB

55-I. 二叉树的深度

https://leetcode-cn.com/problems/er-cha-shu-de-shen-du-lcof/

Java

/*
 * @Author: Goog Tech
 * @Date: 2020-07-21 21:15:19
 * @Description: https://leetcode-cn.com/problems/er-cha-shu-de-shen-du-lcof/
 * @FilePath: \leetcode-googtech\剑指 Offer\#55 - I. 二叉树的深度\Solution.java
 */ 

 /**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */

class Solution {
    // 后序遍历(DFS): 递归法
    public int maxDepth(final TreeNode root) {
        if (root == null) {
            return 0;
        }
        // 递归获取左右子树的深度
        final int leftDepth = maxDepth(root.left) + 1;
        final int rightDepth = maxDepth(root.right) + 1;
        // 利获取最大子树深度
        return leftDepth > rightDepth ? leftDepth:rightDepth;
    }
}

Python

'''
@Author: Goog Tech
@Date: 2020-07-21 21:15:26
@Description: https://leetcode-cn.com/problems/er-cha-shu-de-shen-du-lcof/
@FilePath: \leetcode-googtech\剑指 Offer\#55 - I. 二叉树的深度\Solution.py
'''
# Definition for a binary tree node.
# class TreeNode(object):
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None

class Solution(object):
    # 后序遍历(DFS): 递归法
    def maxDepth(self, root):
        """
        :type root: TreeNode
        :rtype: int
        """
        if not root: return 0
        return max(self.maxDepth(root.left), self.maxDepth(root.right)) + 1