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);
    }
}
相关推荐
入目星河滚烫2 小时前
网易互娱2020校招在线笔试—游戏研发第一批—游泳池-研发
算法·笔试·数据结构与算法
xier_ran2 小时前
【第一周】关键词解释:倒数排名融合(Reciprocal Rank Fusion, RRF)算法
开发语言·python·算法
摸鱼仙人~2 小时前
前端面试最常考、最容易被问崩的 50 道八股精简版
前端·面试·职场和发展
spiritualfood2 小时前
蓝桥杯大学b组水质检测
c语言·c++·算法·青少年编程·职场和发展·蓝桥杯
进击的小头2 小时前
第6篇:贝尔曼最优化理论
python·算法·动态规划
EQUINOX12 小时前
bitset + meet in the middle,P3067 [USACO12OPEN] Balanced Cow Subsets G
算法
四处炼丹2 小时前
OpenClaw本地部署与Multi-Agent 技术分享
人工智能·算法·aigc·agent·ai编程
马士兵教育2 小时前
2026年IT行业基本预测!计算机专业学生就业编程语言Java/C/C++/Python该如何选择?
java·开发语言·c++·人工智能·python·面试·职场和发展
Σίσυφος19002 小时前
周期 Pattern Removal 算法
算法