gpt4 book ai didi

c - 树问题中的递归函数

转载 作者:行者123 更新时间:2023-11-30 14:47:27 25 4
gpt4 key购买 nike

我有一个将二叉树转换为链接列表的函数。我无法理解递归在这里是如何工作的,因为 flatten_helper 函数返回 void。那么当递归函数返回 void 时实际上会发生什么?有人可以帮助我理解这里的代码发生了什么吗?

此外,任何理解树问题中的递归的链接都将受到高度赞赏,因为我正在努力掌握这些类型的问题。

void flatten_helper(struct TreeNode* root, struct TreeNode** prev)
{
if (root == NULL) return;
flatten_helper(root->right, prev);
flatten_helper(root->left, prev);
root->right = *prev;
root->left = NULL;
*prev = root;
}
void flatten(struct TreeNode* root)
{
struct TreeNode **prev;
prev = (struct TreeNode *)malloc(sizeof(struct TreeNode *));
*prev = NULL;
flatten_helper(root, prev);
*prev = NULL;
free(prev);
}

代码积分 - Leetcode

最佳答案

不要将 flatten_helper() 视为一个函数,而应将其视为一个过程。它不返回值,它实际上做了一些工作(它将 root->right 设置为 *prev,root->left 设置为 NULL,并将 *prev 设置为 root)。

关于c - 树问题中的递归函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51228663/

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