Skip to content

Latest commit

 

History

History
59 lines (44 loc) · 1.06 KB

File metadata and controls

59 lines (44 loc) · 1.06 KB

题目描述

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

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

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

示例:

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

    3
   / \
  9  20
    /  \
   15   7

返回它的最小深度  2.

解题思路

具体解法

  1. BFS

Golang

func minDepth(root *TreeNode) int {
	if root == nil {
		return 0
	}
	count := 1
	queue := []*TreeNode{root}
	for len(queue) > 0 {
		l := len(queue)
		for i := 0; i < l; i++ {
			node := queue[i]
			if node.Left == nil && node.Right == nil {
				return count
			}
			if node.Left != nil {
				queue = append(queue, node.Left)
			}
			if node.Right != nil {
				queue = append(queue, node.Right)
			}
		}
		count++
		queue = queue[l:]
	}
	return count
}