Leetcode111 二叉树的最小深度

这篇博客介绍了如何计算二叉树的最小深度,提供了两种解法:递归和广度优先搜索(BFS)。递归方法通过分别计算非叶子节点的左右子树深度来找到最小深度;而BFS方法则利用队列进行层次遍历,一旦找到叶子节点即返回其深度。这两种方法都是有效的解决方案。
摘要由CSDN通过智能技术生成

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

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

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

方法1:递归

方法一:深度优先搜索
思路及解法

首先可以想到使用深度优先搜索的方法,遍历整棵树,记录最小深度。

对于每一个非叶子节点,我们只需要分别计算其左右子树的最小叶子节点深度。这样就将一个大问题转化为了小问题,可以递归地解决该问题。

实现代码:

public int minDepth(TreeNode root) {
    if(root == null)
        return 0;

     if (root.left == null && root.right == null) {
            return 1;
    }
    int minDepth = Integer.MAX_VALUE;
    if(root.left != null){
        minDepth = Math.min(minDepth,minDepth(root.left));
    }
    if(root.right != null){
        minDepth = Math.min(minDepth,minDepth(root.right));
    }
    return minDepth + 1;

}

方法2:迭代

方法二:广度优先搜索(BFS Breadth--first-search)
思路及解法

同样,我们可以想到使用广度优先搜索的方法,遍历整棵树。

当我们找到一个叶子节点时,直接返回这个叶子节点的深度。广度优先搜索的性质保证了最先搜索到的叶子节点的深度一定最小。

public int minDepth(TreeNode root) {
    if(root == null)
        return 0;
    Queue<TreeNode> q = new LinkedList<>();
    int depth = 1;
    q.offer(root);
    while(!q.isEmpty()){
        int size = q.size();
        for(int i = 0; i < size;i++){
            TreeNode cur = q.poll();
            if(cur.left == null && cur.right == null){
                return depth;
            }
            if(cur.left != null){
                q.offer(cur.left);
            }
             if(cur.right != null){
                q.offer(cur.right);
            }

        }
        depth += 1;

    }
    return depth;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值