首页 » C++ » 剑指Offer(55)二叉树的深度

剑指Offer(55)二叉树的深度

原文 http://blog.csdn.net/Haiqiang1995/article/details/79179804

2018-01-28 02:00:40阅读(435)

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

算法:遍历算法 数据结构:二叉树 编程语言:C++
/*
struct TreeNode {
    int val;
    struct TreeNode *left;
    struct TreeNode *right;
    TreeNode(int x) :
            val(x), left(NULL), right(NULL) {
    }
};*/
class Solution {
public:
    int TreeDepth(TreeNode* pRoot)
    {
       if(pRoot==nullptr)
           return 0;
        //左子树的深度
       int mleft=TreeDepth(pRoot->left);
        //右子树的深度
       int mright=TreeDepth(pRoot->right);
        //算法思想:如果根节点只有右子树没有左子树,那么树的深度是右子树深度加1
        //如果根节点只有左子树没有右子树,那么树的深度是左子树深度加1,所以最终的树的深度是左右子树中
        //较长的子树的深度加1,
        return (mleft>mright)?mleft+1:mright+1;
    }
};

最新发布

CentOS专题

关于本站

5ibc.net旗下博客站精品博文小部分原创、大部分从互联网收集整理。尊重作者版权、传播精品博文,让更多编程爱好者知晓!

小提示

按 Ctrl+D 键,
把本文加入收藏夹