gpt4 book ai didi

c++ - 二叉搜索树的最大深度

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:45:59 25 4
gpt4 key购买 nike

我想找到二叉搜索树的最大深度。我找到了一个代码。

int maxDepth(struct node* node) { 
if (node==NULL) {
return(0);
}
else {
// compute the depth of each subtree
int lDepth = maxDepth(node->left);
int rDepth = maxDepth(node->right);
// use the larger one
if (lDepth > rDepth) return(lDepth+1);
else return(rDepth+1);
}
}

我想知道 node->left 怎么会返回 1 ?

是默认的吗?代码很简单,但我不知道答案从何而来,谁能解释一下?

最佳答案

给定这棵树:

[一]

/\

[B] [C]

对于带 NULL 的 [B] 和带 NULL 的 [C] 将调用 maxDepth,两者都返回零,因此递归调用最终返回 0+1。

如果 [C] 下有一个节点 [D],那么对 [D] maxDepth 的调用将返回 NULL,D 将返回 0+1,然后递归将继续扩大,[C] 将收到 0+1并将一些 +1,返回 maxDepth 2,它大于包含 [B] 的分支的深度,即 1,因此从完整递归返回 maxDepth 2。

关于c++ - 二叉搜索树的最大深度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23146843/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com