给定一个二叉树,返回它的中序 遍历。
示例:
输入: [1,null,2,3] 1 \ 2 / 3 输出: [1,3,2]
进阶: 递归算法很简单,你可以通过迭代算法完成吗?
思路:
1.递归中序遍历
2.迭代中序遍历
3.莫里斯遍历
题解:
1.
//递归中序遍历
class Solution {
public:
vector<int> v;
void traversal(TreeNode* root) {
if (root!=NULL) {
traversal(root->left);
v.push_back(root->val);
traversal(root->right);
}
}
vector<int> inorderTraversal(TreeNode* root) {
traversal(root);
return v;
}
};
//利用栈,迭代中序遍历
class Solution {
public:
vector<int> v;
stack<TreeNode*> s;
int i = 0;
vector<int> inorderTraversal(TreeNode* root) {
if (root==NULL)
return v;
s.push(root);
root = root->left;
while (!s.empty() || root!=NULL) {
while (root!=NULL) {
s.push(root);
root = root->left;
}
root = s.top();
s.pop();
v.push_back(root->val);
root = root->right;
}
return v;
}
};
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/binary-tree-inorder-traversal