leetcode:94. 二叉树的中序遍历
题目
给定一个二叉树的根节点 root ,返回它的 中序 遍历。
示例 1:
示例 1:![[简单] 94. 二叉树的中序遍历 - 图1](/uploads/projects/liangduo-rjrcs@ggu4wq/01c5456ea37f22f1c0e7bd4813a3c12c.jpeg)
输入:root = [1,null,2,3]输出:[1,3,2]
示例 2:
输入:root = []输出:[]
示例 3:
输入:root = [1]输出:[1]
示例 4:![[简单] 94. 二叉树的中序遍历 - 图2](/uploads/projects/liangduo-rjrcs@ggu4wq/8dd8d5e16abd76f32b4ebe92ed0ec37d.jpeg)
输入:root = [1,2]输出:[2,1]
示例 5:![[简单] 94. 二叉树的中序遍历 - 图3](/uploads/projects/liangduo-rjrcs@ggu4wq/487bcca3793b053c6786f66122229071.jpeg)
输入:root = [1,null,2]输出:[1,2]
解答 & 代码
解法一:递归
/*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) {}* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}* TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/class Solution {private:vector<int> result;void inOrder(TreeNode* root){if(root == nullptr)return;inOrder(root->left);result.push_back(root->val);inOrder(root->right);}public:vector<int> inorderTraversal(TreeNode* root) {inOrder(root);return result;}};
复杂度分析:设二叉树共 N 个节点
- 时间复杂度 O(N):遍历每个节点一次
- 空间复杂度 O(log N):栈空间取决于递归深度,即二叉树的高度
执行结果:
执行结果:通过执行用时:0 ms, 在所有 C++ 提交中击败了 100.00% 的用户内存消耗:8.3 MB, 在所有 C++ 提交中击败了 14.25% 的用户
解法二:迭代
二叉树的前/中/后序/层序遍历
复杂度分析:设二叉树共 N 个节点
- 时间复杂度 O(N):遍历每个节点一次
- 空间复杂度 O(log N):结果数组
result的空间复杂度不计入,栈nodeS中同时存储的节点数的最大值取决于二叉树的深度,因此空间复杂度 O(log N)
执行结果:
执行结果:通过执行用时:4 ms, 在所有 C++ 提交中击败了 39.89% 的用户内存消耗:8.3 MB, 在所有 C++ 提交中击败了 12.90% 的用户
