剑指Offer第三十八题:二叉树的深度

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

思路:深度优先遍历,先从最下面一个节点开始,高度初始为1,然后上升到父节点,比较父节点的左右两个子树的高度,取较高的高度然后加一作为父节点的高度。
public class Solution {

public int TreeDepth(TreeNode pRoot)
{
    if(pRoot == null){
        return 0;
    }
    int left = TreeDepth(pRoot.left);
    int right = TreeDepth(pRoot.right);
    return Math.max(left, right) + 1;
}

}

第二种思路:从上往下遍历,每向下走一层,高度加+1;
public class Q_38 {

public int TreeDepth(TreeNode root) {
    if (root == null) return 0;
    return TreeDepth(root, 1);
}

public int TreeDepth(TreeNode root, int high) {
    if (root.left != null && root.right != null) {
        return Math.max(TreeDepth(root.left, high + 1), TreeDepth(root.right, high + 1));
    } else if (root.left != null) {
        return TreeDepth(root.left, high + 1);
    } else if (root.right != null) {
        return TreeDepth(root.right, high + 1);
    } else {
        return high;
    }
}

}

全部评论

相关推荐

没测评没笔试没感谢信直接无了
投递联发科技等公司10个岗位
点赞 评论 收藏
分享
07-11 22:27
中南大学 Java
程序员牛肉:学历的话没问题。但是没问题的也就只有学历了。 其实你的整体架构是正确的,博客接着干。但是项目有点过于简单了。从后端的角度上讲,你这也就是刚入门的水平,所以肯定约面试够呛。 如果你要应聘后端岗位,那你第一个项目竟然是仿写操作系统。这个你要面试官咋问你。你一定要记住一点,你简历上写的所有的东西,都是为了证明你有能力胜任当前的岗位,而不是为了证明你自己会什么。 如果你只是浅浅的做几个项目,描述也都是烂大街。技术点也都是各种混水类的配置类需求,那你就不要幻想自己能走多远。一定要保持思考,保持学习。
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
06-11 17:39
小呆呆的大鼻涕:卧槽,用户彻底怒了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务