代码随想录二刷 |二叉树 |二叉树的中序遍历
- 题目描述
- 解题思路
- 代码实现
- 迭代法
- 递归法
题目描述
94.二叉树的中序遍历
给定一个二叉树的根节点 root ,返回 它的 中序 遍历 。
示例 1:
输入:root = [1,null,2,3]
输出:[1,3,2]
示例 2:
输入:root = []
输出:[]
示例 3:
输入:root = [1]
输出:[1]
提示:
- 树中节点数目在范围 [0, 100] 内
- -100 <= Node.val <= 100
解题思路
在处理的节点放入栈之后,紧接着放入一个空指针作为标记
代码实现
迭代法
class Solution {
public:void traversal(TreeNode* cur, vector<int>& vec) {if (cur == NULL) return;traversal(cur->left, vec);vec.push_back(cur->val);traversal(cur->right, vec);}vector<int> inorderTraversal(TreeNode* root) {vector<int> result;traversal(root, result);return result;}
};
递归法
// 中序遍历:左中右
// 入栈顺序:右中左
class Solution {
public:vector<int> inorderTraversal(TreeNode* root) {vector<int> result;stack<TreeNode*> st;if (root != NULL) st.push(root);while (!st.empty()) {TreeNode* node = st.top();if (node != NULL) {st.pop();if (node->right) st.push(node->right);st.push(node);st.push(NULL);if (node->left) st.push(node->left);} else {st.pop();node = st.top();st.pop();result.push_back(node->val);}}return result;}
};