二叉树深度递归与非递归

/*
struct TreeNode {
int val;
struct TreeNode left;
struct TreeNode *right;
TreeNode(int x) :
val(x), left(NULL), right(NULL) {
}
};
/
二叉树递归即是分治的思想,和归并排序类似
二叉树的深度递归计算即是在回溯过程中计算,每一次回溯都去左右子树的最大值
可以将一颗二叉树想成一个根节点和两颗左右整体子树,最后的结果肯定是左右子树的高度取最大值+1

二叉树非递归即是借助于队列的思想,和层次遍历类似
每一次必须把每一层的结点都出队后才能使高度+1,直到队空返回level高度即可
class Solution {
public:
//递归
int TreeDepth(TreeNode* pRoot)
{
if (pRoot == NULL) return 0;

    int leftnum = TreeDepth(pRoot -> left);
    int rightnum = TreeDepth(pRoot -> right);

    return (leftnum > rightnum ? leftnum : rightnum) + 1;
}
//非递归
int TreeDepth(TreeNode* pRoot)
{
    if (!pRoot) return 0;
    queue<TreeNode*> Q;
    Q.push(pRoot);
    int level = 0;
    while (!Q.empty())
    {
        int sz = Q.size();
        while (sz --)
        {
            auto node = Q.front(); Q.pop();
            if (node -> left) Q.push(node -> left);
            if (node -> right) Q.push(node -> right);
        }
        level++;
    }
    return level;
}

};

全部评论

相关推荐

不愿透露姓名的神秘牛友
06-23 18:34
点赞 评论 收藏
分享
05-26 10:24
门头沟学院 Java
qq乃乃好喝到咩噗茶:其实是对的,线上面试容易被人当野怪刷了
点赞 评论 收藏
分享
06-08 22:25
门头沟学院 Java
从零开始的转码生活:这hr不会打开手机不分青红皂白给所有人群发这句话,过一会再给所有人再发一遍,这肯定会有重复的,不管,再过一会再发一遍
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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