LeetCode:111. 二叉树的最小深度

简介

题目链接:https://leetcode.cn/problems/minimum-depth-of-binary-tree/description/

解决方式:深度优先搜索 + 递归

这是作者学习众多大神的思路进行解题的步骤,很推荐大家解题的时候去看看题解里面大佬们的思路、想法!

推荐查看灵茶山艾府大佬所作题解。

DFS

解题思路是一直往下递归,同时传递当前深度。当遇到叶子结点就比较当前深度与全局深度谁更小。

java 复制代码
class Solution {

    // 最小深度。
    // 刚开始设置最大,方便存放较小值
    private int ans = Integer.MAX_VALUE;

    public int minDepth(TreeNode root) {
        dfs(root, 0);
        return root == null ? 0 : ans;
    }

    // 递归函数
    private void dfs(TreeNode root, int cnt){
        // 递归终止条件
        if(root == null){
            return;
        }
        // 递归公式
        // 递到某一节点,深度 + 1 
        cnt++;
        // 该节点是叶子结点,比较全局存下的最下值和当前递归得到的哪个更小
        if(root.right == null && root.left == null){
            ans = Math.min(ans, cnt);
            return;
        }
        // 该节点非叶子结点,继续递归
        dfs(root.left, cnt);
        dfs(root.right, cnt);
    }
}

优化,最优性剪枝

java 复制代码
class Solution {

    // 最小深度。
    // 刚开始设置最大,方便存放较小值
    private int ans = Integer.MAX_VALUE;

    public int minDepth(TreeNode root) {
        dfs(root, 0);
        return root == null ? 0 : ans;
    }

    // 递归函数
    private void dfs(TreeNode root, int cnt){
        // 递归终止条件
        if(root == null || ++cnt >= ans){   // 最优性剪枝,预先判断深度是否比全局最小深度大,若大或相等,则没必要继续往下递归了
            return;
        }
        // 递归公式
        // 该节点是叶子结点,比较全局存下的最下值和当前递归得到的哪个更小
        if(root.right == null && root.left == null){
            ans = cnt;
            return;
        }
        // 该节点非叶子结点,继续递归
        dfs(root.left, cnt);
        dfs(root.right, cnt);
    }
}
相关推荐
foundbug9992 小时前
基于混合整数规划的电池容量优化 - MATLAB实现
数据结构·算法·matlab
chutao2 小时前
EasyPDF 转图片(EasyPdf2Image)—— 本地安全实用的PDF与图片双向互转工具
安全·职场和发展·pdf·创业创新·学习方法
海绵宝宝的月光宝盒2 小时前
2-非金属材料
经验分享·笔记·学习·其他·职场和发展·课程设计·制造
memcpy03 小时前
LeetCode 2452. 距离字典两次编辑以内的单词【暴力;字典树】中等
算法·leetcode·职场和发展
王老师青少年编程3 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【排序贪心】:魔法
c++·算法·贪心·csp·信奥赛·排序贪心·魔法
wearegogog1233 小时前
基于和差波束法的单脉冲测角MATLAB实现
人工智能·算法·matlab
AI科技星4 小时前
灵魂商数(SQ) · 全域数学统一定义【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
晓觉儿4 小时前
【GPLT】2026年第十一届团队程序设计天梯赛赛后题解(已写2h,存档中)
数据结构·c++·算法·深度优先·图论
We་ct4 小时前
LeetCode 322. 零钱兑换:动态规划入门实战
前端·算法·leetcode·typescript·动态规划
6Hzlia4 小时前
【Hot 100 刷题计划】 LeetCode 394. 字符串解码 | C++ 单栈回压法
c++·算法·leetcode