LeetCode104. Maximum Depth of Binary Tree

给定一个二叉树,找出其最大深度。

二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。

说明: 叶子节点是指没有子节点的节点。

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

3

/
9 20
/
15 7
返回它的最大深度 3 。

思路:递归左右两条路,用x来记录到多少层,取两条路的最大层数

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
class Solution {
    public int maxDepth(TreeNode root) {
        if(root == null)
        {
            return 0;
        }
        else
        {
            return Math.max(maxDepth(root.left, 1),maxDepth(root.right, 1));
        }
    }
    public int maxDepth(TreeNode root, int x) 
    {
        if(root == null)
        {
            return x;
        }
        else
        {
            return Math.max(maxDepth(root.left, x+1),maxDepth(root.right, x+1));
        }
    }
}

猜你喜欢

转载自blog.csdn.net/qq_43274298/article/details/88907477