迷·夜辉 2022-07-24 15:53 采纳率: 100%
浏览 16
已结题

求二叉树高度用++永远返回0

练习数据结构的时候发现求二叉树高度的时候用L++和R++,返回的数值是0,而用L+1和R+1能返回正确的数值,这是为什么呢

int TreeDepth(TreeNode* pRoot) {
    if (pRoot == NULL) {
        return 0;
    }
    int L = TreeDepth(pRoot->lchild);
    int R = TreeDepth(pRoot->rchild);
    return L > R ? L+1 : R+1;  //能正确返回高度
}

int TreeDepth(TreeNode* pRoot) {
    if (pRoot == NULL) {
        return 0;
    }
    int L = TreeDepth(pRoot->lchild);
    int R = TreeDepth(pRoot->rchild);
    return L > R ? L+1 : R+1;  //不能正确返回高度
//注意不能用 return L > R ? L++ : R++;原因暂时不明
}

  • 写回答

1条回答 默认 最新

  • 林地宁宁 2022-07-24 22:45
    关注

    注意 L++ 这种是后自增运算符,会先返回 L 的值之后,再把 L 的值加一,因此如果用第二个写法,某种程度上等价于:

    int TreeDepth(TreeNode* pRoot) {
        if (pRoot == NULL) {
            return 0;
        }
        int L = TreeDepth(pRoot->lchild);
        int R = TreeDepth(pRoot->rchild);
        return L > R ? L : R;  //不能正确返回高度
        L += 1;
        R += 1;
    }
    

    显然,能看到 +1 的操作在 return 之后,那么相当于没有 +1,结果也就是 0 了。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 8月1日
  • 已采纳回答 7月24日
  • 创建了问题 7月24日

悬赏问题

  • ¥15 乌班图ip地址配置及远程SSH
  • ¥15 怎么让点阵屏显示静态爱心,用keiluVision5写出让点阵屏显示静态爱心的代码,越快越好
  • ¥15 PSPICE制作一个加法器
  • ¥15 javaweb项目无法正常跳转
  • ¥15 VMBox虚拟机无法访问
  • ¥15 skd显示找不到头文件
  • ¥15 机器视觉中图片中长度与真实长度的关系
  • ¥15 fastreport table 怎么只让每页的最下面和最顶部有横线
  • ¥15 R语言卸载之后无法重装,显示电脑存在下载某些较大二进制文件行为,怎么办
  • ¥15 java 的protected权限 ,问题在注释里