剑指Offer 面试题55 - I. 二叉树的深度(Java代码)

题目描述

输入一棵二叉树的根节点,求该树的深度。从根节点到叶节点依次经过的节点(含根、叶节点)形成树的一条路径,最长路径的长度为树的深度。

输入输出样例

给定二叉树 [3,9,20,null,null,15,7]

    3
   / \
  9  20
    /  \
   15   7

返回它的最大深度 3 。

题解

求二叉树的深度:

  • 问题可以转换成,max(左右两边的子树深度) + 1
  • 由于首先要比较左右两个子树深度,所以使用后序遍历
  • 当递归到叶子节点的时候,返回0
class Solution {
     
    public int maxDepth(TreeNode root) {
     
        if(root == null) return 0;
        int left = maxDepth(root.left);
        int right = maxDepth(root.right);
        return Math.max(left, right) + 1;
    }
}

你可能感兴趣的:(剑指Offer)