给定一个二叉树,找出其最小深度。
最小深度是从根节点到最近叶子节点的最短路径上的节点数量。
说明: 叶子节点是指没有子节点的节点。
示例:
给定二叉树 [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)
};