LeeCode 94. 二叉树的中序遍历
给定一个二叉树的根节点 root
,返回 它的 中序 遍历 。
示例 2:
输入:root = [] 输出:[]
示例 3:
输入:root = [1] 输出:[1]
提示:
- 树中节点数目在范围
[0, 100]
内 -100 <= Node.val <= 100
进阶: 递归算法很简单,你可以通过迭代算法完成吗?
答案&测试代码:
void testLeeCode94() { // 94.二叉树的中序遍历。 中序遍历:按照访问左子树——根节点——右子树的方式遍历这棵树/*** 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 {public:vector<int> inorderTraversal(TreeNode* root) {vector<int> vec;if (root) {vector<int> left = inorderTraversal(root->left);vec.insert(vec.end(), left.begin(), left.end()); // 全部加进去vec.push_back(root->val);vector<int> right = inorderTraversal(root->right);vec.insert(vec.end(), right.begin(), right.end());}return vec;}};// 测试示例1TreeNode node1(1), node2(2), node3(3);node1.right = &node2;node2.left = &node3;Solution solution;vector<int> vec = solution.inorderTraversal(&node1);for (auto val : vec) {cout << val << endl;}
}
打印:
ok, 提交到LeeCode:
ok