求给定二叉树的最小深度。最小深度是指树的根结点到最近叶子结点的最短路径上结点的数量。
Given a binary tree, find its minimum depth.The minimum depth is the number of nodes along the shortest path from the root node down to the nearest leaf node.
注意!这个求得是给定二叉树的最小深度。最小深度是指树的根结点到最近叶子结点的最短路径上结点的数量。
一定要到叶子节点!!!所以当某一边没有节点的时候,需要舍弃
package main
type TreeNode struct {
Val int
Left *TreeNode
Right *TreeNode
}
func run(root *TreeNode) int {
// write code here
if root == nil {
return 0
}
leftDepth := run(root.Left) + 1
rightDepth := run(root.Right) + 1
if root.Left != nil && root.Right != nil {
if leftDepth > rightDepth {
return rightDepth
}
return leftDepth
} else {
if leftDepth > rightDepth {
return leftDepth
}
return rightDepth
}
}
878

被折叠的 条评论
为什么被折叠?



