zoukankan      html  css  js  c++  java
  • 二叉树的最小深度

    二叉树的最小深度

    给定一个二叉树,找出其最小深度。
    最小深度是从根节点到最近叶子节点的最短路径上的节点数量。
    说明: 叶子节点是指没有子节点的节点。

    示例

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

        3
       / 
      9  20
        /  
       15   7
    

    题解

    /**
     * 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) {
        if(!root) return 0;
        if(root.left === null && root.right !== null) return minDepth(root.right) + 1;
        if(root.right === null && root.left !== null) return minDepth(root.left) + 1;
        var lh = minDepth(root.left);
        var rh = minDepth(root.right);
        return Math.min(lh, rh) + 1;
    };
    

    思路

    使用深度优先搜索的方法,遍历整棵树对比最小高度的子树并记录,返回最小高度子树的高度,对于每一个非叶子节点,只需要分别计算其左右子树的最小叶子节点深度即可,注意题目中定义最小深度是从根节点到最近叶子节点的最短路径上的节点数量,且叶子节点是指没有子节点的节点,所以有两个节点的二叉树的最小深度是2。首先如果节点没有定义,那么就认为其高度为0并返回0,对于题目中的要求最小深度是从根节点到最近叶子节点的最短路径上的节点数量,所以在左子树不存在右子树存在的情况下,返回右子树的最小深度+1,如果在右子树不存在左子树存在的情况下,返回左子树的最小深度+1,然后取得左子树的最小深度与右子树的最小深度,比较大小,返回较小子树深度+1

    每日一题

    https://github.com/WindrunnerMax/EveryDay
    

    参考

    https://leetcode-cn.com/problems/minimum-depth-of-binary-tree/
    
  • 相关阅读:
    图像检索(image retrieval)- 11
    图像检索(image retrieval)- 10相关
    Mock.js简易教程,脱离后端独立开发,实现增删改查功能
    Azure Monitor (3) 对虚拟机磁盘设置自定义监控
    Azure Monitor (1) 概述
    Azure SQL Managed Instance (2) 备份SQL MI
    Azure Virtual Network (17) Private Link演示
    Azure Virtual Network (16) Private Link
    Azure Virtual Network (15) Service Endpoint演示
    Azure Virtual Network (14) Service Endpoint服务终结点
  • 原文地址:https://www.cnblogs.com/WindrunnerMax/p/13542995.html
Copyright © 2011-2022 走看看