-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathleetcode-94-Binary_Tree_Inorder_Traversal.cpp
62 lines (50 loc) · 1.23 KB
/
leetcode-94-Binary_Tree_Inorder_Traversal.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
/* -- Id = 94 -- */
#include <cstdlib>
#include <iostream>
#include <vector>
// 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) {}
};
void addTovecF(std::vector<int> &vec, TreeNode* root)
{
if(root == nullptr)
return;
else {
addTovecF(vec, root->left);
vec.push_back(root->val);
addTovecF(vec, root->right);
}
}
std::vector<int> inorderTraversal(TreeNode* root) {
std::vector<int> vec;
addTovecF(vec, root);
return vec;
}
int main(int argc, char const *argv[])
{
TreeNode* root = new TreeNode;
TreeNode* t1 = new TreeNode;
TreeNode* t2 = new TreeNode;
root->val = 1;
t1->val = 2;
t2->val = 3;
root->left = nullptr;
root->right = t1;
t1->left = t2;
t1->right = nullptr;
t2->left = t2->right = nullptr;
std::vector<int> v = inorderTraversal(root);
for (auto &i : v)
{
std::cout << i << " ";
}
std::cout << std::endl;
return EXIT_SUCCESS;
}