Skip to content

Latest commit

 

History

History
48 lines (40 loc) · 894 Bytes

111. 二叉树的最小深度.md

File metadata and controls

48 lines (40 loc) · 894 Bytes

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

最小深度是从根节点到最近叶子节点的最短路径上的节点数量。

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

示例:

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

    3
   / \
  9  20
    /  \
   15   7

返回它的最小深度  2.

solution:

/**
 * Definition for a binary tree node.
 * function TreeNode(val) {
 *     this.val = val;
 *     this.left = this.right = null;
 * }
 */
/**
 * @param {TreeNode} root
 * @return {number}
 */
var minDepth = function(root) {
    function min (node) {
        if (!node) return 0
        if (node.left === null) {
            return 1 + min(node.right)
        }
        if (node.right === null) {
            return 1 + min(node.left)
        }
        return 1 + Math.min(min(node.left), min(node.right))
    }
    return min(root)
};