2302_79644694 2024-05-04 01:08 采纳率: 42.9%
浏览 4

后序遍历基础上求二叉树的深度

请问这样能准确计算二叉树的深度吗(deep初始调用时传入1,max默认为1)
根节点为空时特殊处理


int max=1;
//递归先序遍历
void RecurPreVisit(BTNode *p,int deep)
{
    if(p==NULL) return;


    RecurPreVisit(p->lchild,deep+1);
    RecurPreVisit(p->rchild,deep+1);

    //操作
    //-----------------------------------------
    //printf("%d ",p->data);

    if(deep>max) max=deep;


    //-----------------------------------------
}
  • 写回答

4条回答 默认 最新

  • 专家-赤兔[在线] 全栈领域优质创作者 2024-05-04 01:08
    关注

    引自免费微信小程序:皆我百晓生

    在您提供的代码片段中,您正在尝试通过后序遍历来计算二叉树的深度。然而,这段代码实际上是实现了一个先序遍历而不是后序遍历。为了根据后序遍历计算二叉树的深度,我们需要调整遍历顺序,确保左子树、右子树以及根节点的访问顺序正确。

    以下是修正后的后序遍历函数,用于计算二叉树的深度:

    int max = 1; // 初始化最大深度为1,因为至少有一个根节点
    
    // 后序遍历
    void RecurPostVisit(BTNode* p, int& deep)
    {
        if (p == NULL) return;
    
        // 先遍历左右子树
        RecurPostVisit(p->lchild, deep);
        RecurPostVisit(p->rchild, deep);
    
        // 当前节点处理完之后更新深度
        if (deep < 1 + max) // 使用<而非>
            max = deep + 1;
    }
    
    // 主函数,从根节点开始调用
    void CalculateTreeDepth(BTNode* root)
    {
        RecurPostVisit(root, max);
        printf("The depth of the tree is: %d\n", max);
    }
    

    在这个版本中,我们首先遍历左子树,然后遍历右子树,最后处理根节点。这样可以确保我们总是对最远的叶子节点进行深度检查。注意,我们在RecurPostVisit函数中使用了引用传递deep参数,以便在递归过程中修改它。同时,在判断新深度是否更大的条件语句中,使用了<而非>,因为我们需要找到最小的深度值来表示整个树的最大深度。最后,在主函数CalculateTreeDepth中,调用RecurPostVisit并输出结果。

    评论 编辑记录

报告相同问题?

问题事件

  • 创建了问题 5月4日

悬赏问题

  • ¥200 csgo2的viewmatrix值是否还有别的获取方式
  • ¥15 Stable Diffusion,用Ebsynth utility在视频选帧图重绘,第一步报错,蒙版和帧图没法生成,怎么处理啊
  • ¥15 请把下列每一行代码完整地读懂并注释出来
  • ¥15 pycharm运行main文件,显示没有conda环境
  • ¥15 易优eyoucms关于二级栏目调用的问题
  • ¥15 寻找公式识别开发,自动识别整页文档、图像公式的软件
  • ¥15 为什么eclipse不能再下载了?
  • ¥15 编辑cmake lists 明明写了project项目名,但是还是报错怎么回事
  • ¥15 关于#计算机视觉#的问题:求一份高质量桥梁多病害数据集
  • ¥15 特定网页无法访问,已排除网页问题