剑指Offer系列:二叉树的深度

该文章介绍了一个计算二叉树深度的问题,通过输入一棵二叉树的结构,利用递归方法遍历每个节点,记录路径深度并找到最大值。提供的代码示例展示了如何实现这个功能,其中`findDepth`函数用于递归计算节点深度,并存储在列表中,最后返回列表的最大值作为树的深度。

2023/01/01 08:22:26 by: 程序员·小李

题目描述

输入一棵二叉树,求该树的深度。从根结点到叶结点依次经过的结点(含根、叶结点)形成树的一条路径,最长路径的长度为树的深度,根节点的深度视为 1 。

数据范围:节点的数量满足 0≤n≤100 ,节点上的值满足 0≤val≤100 进阶:空间复杂度 O(1),时间复杂度 O(n)

假如输入的用例为{1,2,3,4,5,#,6,#,#,7},那么如下图:

解题思路

将每一条链路递归到,看一下最大值是多少。

代码实现

/**
public class TreeNode {
    int val = 0;
    TreeNode left = null;
    TreeNode right = null;

    public TreeNode(int val) {
        this.val = val;

    }

}
*/
public class Solution {
    public int TreeDepth(TreeNode root) {
        java.util.List<Integer> depthList = new java.util.ArrayList<Integer>();
        findDepth(root, depthList, 0);

        // 不存在节点
        if (depthList.size() == 0){
            return 0;
        }

        // 最大值
        int max = Integer.MIN_VALUE;
        for (Integer ele : depthList){
            if (ele > max){
                max = ele;
            }
        }
        return max;
    }

    private void findDepth(TreeNode node, java.util.List<Integer> res, int depth){
        if (node == null){
            return;
        }

        depth += 1;
        res.add(depth);
        findDepth(node.left, res, depth);
        findDepth(node.right, res, depth);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值