104. Maximum Depth of Binary Tree

1. Description

Given the root of a binary tree, return its maximum depth.
A binary tree’s maximum depth is the number of nodes along the longest path from the root node down to the farthest leaf node.

2. Example

Example 1

Example 1
Input: root = [3,9,20,null,null,15,7]
Output: 3

Example 2

Input: root = [1,null,2]
Output: 2

3. Constraints

  • The number of nodes in the tree is in the range [0, $10^4$].
  • -100 <= Node.val <= 100

4. Solutions

Recursive

n is the number of nodes in root
Time complexity: O(n)
Space complexity: O(n)

class Solution {
public:
    int maxDepth(TreeNode *root) {
        return root == nullptr ? 0 : 1 + max(maxDepth(root->left), maxDepth(root->right));
    }
};
comments powered by Disqus