您的位置:首页 > 汽车 > 时评 > 【LeetCode算法】第94题:二叉树的中序遍历

【LeetCode算法】第94题:二叉树的中序遍历

2024/11/17 22:40:27 来源:https://blog.csdn.net/weixin_46249470/article/details/139305622  浏览:    关键词:【LeetCode算法】第94题:二叉树的中序遍历

目录

一、题目描述

二、初次解答

三、官方解法

四、总结


一、题目描述

二、初次解答

1. 思路:二叉树的中序遍历。访问二叉树的左子树,再访问二叉树的根节点,最后访问二叉树的右叉树。

2. 代码:

void order(struct TreeNode* root, int* ret, int* p){if(!root)return;order(root->left, ret, p);ret[(*p)++]=root->val;order(root->right, ret, p);
}int* inorderTraversal(struct TreeNode* root, int* returnSize) {int* ret=(int*)malloc(sizeof(int)*100);*returnSize=0;order(root, ret, returnSize);return ret;
}

3. 优点:实现简单,容易想到,且仅需遍历一遍,时间复杂度为O(n)。

4. 缺点:需要递归栈空间,空间复杂度为O(n)。

三、官方解法

1. 思路:迭代遍历二叉树,手动维护栈。每次迭代访问子节点前,将当前节点地址保存到栈内,访问完左节点后,再访问当前节点,最后访问右节点。

2. 代码:

int* inorderTraversal(struct TreeNode* root, int* returnSize) {int* ret=malloc(sizeof(int)*100);struct TreeNode** tmp=malloc(sizeof(struct TreeNode*)*100);int top=0;*returnSize=0;while(root || top>0){while(root){tmp[top++]=root;root=root->left;}root=tmp[--top];ret[(*returnSize)++]=root->val;root=root->right;}return ret;
}

3. 优点:符合不采用迭代的要求,且时间复杂度为O(n)。

4. 缺点:手动维护栈,空间复杂度依旧为O(n)。

四、总结

当遇到二叉树中序遍历时,使用递归实现最简单,也可以采用迭代手动维护栈空间来实现。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com