码迷,mamicode.com
首页 > 编程语言 > 详细

【数据结构与算法】二叉树——二叉树的最小深度

时间:2020-04-19 11:17:51      阅读:76      评论:0      收藏:0      [点我收藏+]

标签:binary   int   一个   etc   tco   minimum   描述   leetcode   problems   

二叉树的最小深度

LeetCode:二叉树的最小深度

题目描述:

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

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

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

示例:

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

    3
   /   9  20
    /     15   7
返回它的最小深度 ?2.

思想:

还是递归,没啥特别的

代码

我的第一遍代码:

public int minDepth(TreeNode root) {
    if(root==null)
        return 0;
    if(root.left==null&&root.right==null)
        return 1;
    if(root.left==null)
        return 1+minDepth(root.right);
    if(root.right==null)
        return 1+minDepth(root.left);
    return 1+Math.min(minDepth(root.left),minDepth(root.right));
}

优化之后:

class Solution {
    public int minDepth(TreeNode root) {
        if(root==null) return 0;
        int x=minDepth(root.right);
        int y=minDepth(root.left);
        if(x==0||y==0)
            return x+y+1;
        return Math.min(x,y)+1;
    }
}

if(x == 0||y==0) return x+y+1; 非常妙

【数据结构与算法】二叉树——二叉树的最小深度

标签:binary   int   一个   etc   tco   minimum   描述   leetcode   problems   

原文地址:https://www.cnblogs.com/buptleida/p/12730410.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!