【LeetCode】144. Binary Tree Preorder Traversal (3 solutions)
2014-11-14 16:15
405 查看
Binary Tree Preorder Traversal
Given a binary tree, return the preorder traversal of its nodes' values.
For example:
Given binary tree
return
Note: Recursive solution is trivial, could you do it iteratively?
解法一:递归
解法二:借助栈的非递归,需要记录每个节点是否访问过
解法三:借助栈的非递归,无需记录每个节点是否访问过。
Given a binary tree, return the preorder traversal of its nodes' values.
For example:
Given binary tree
{1,#,2,3},
1 \ 2 / 3
return
[1,2,3].
Note: Recursive solution is trivial, could you do it iteratively?
解法一:递归
/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode(int x) : val(x), left(NULL), right(NULL) {} * }; */ class Solution { public: vector<int> preorderTraversal(TreeNode* root) { vector<int> ret; Helper(ret, root); return ret; } void Helper(vector<int>& ret, TreeNode* root) { if(root) { ret.push_back(root->val); Helper(ret, root->left); Helper(ret, root->right); } } };
解法二:借助栈的非递归,需要记录每个节点是否访问过
/** * Definition for binary tree * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode(int x) : val(x), left(NULL), right(NULL) {} * }; */ class Solution { public: vector<int> preorderTraversal(TreeNode *root) { vector<int> ret; if(root == NULL) return ret; stack<TreeNode*> stk; unordered_map<TreeNode*, bool> visited; stk.push(root); visited[root] = true; while(!stk.empty()) { TreeNode* top = stk.top(); stk.pop(); ret.push_back(top->val); if(top->right != NULL && visited[top->right] == false) { stk.push(top->right); visited[top->right] = true; } if(top->left != NULL && visited[top->left] == false) { stk.push(top->left); visited[top->left] = true; } } return ret; } };
解法三:借助栈的非递归,无需记录每个节点是否访问过。
/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode(int x) : val(x), left(NULL), right(NULL) {} * }; */ class Solution { public: vector<int> preorderTraversal(TreeNode* root) { vector<int> ret; if(root == NULL) return ret; stack<TreeNode*> stk; stk.push(root); while(!stk.empty()) { TreeNode* top = stk.top(); stk.pop(); ret.push_back(top->val); if(top->right) stk.push(top->right); if(top->left) stk.push(top->left); } return ret; } };
相关文章推荐
- 【LeetCode】104. Maximum Depth of Binary Tree (2 solutions)
- 【LeetCode】12. Integer to Roman (2 solutions)
- [LeetCode] My Solutions in LeetCode Online Judge
- LeetCode Questions List (LeetCode 问题列表)- Java Solutions
- 【LeetCode】115. Populating Next Right Pointers in Each Node (2 solutions)
- 【LeetCode】130. Surrounded Regions (2 solutions)
- 【LeetCode】 Same Tree (2 solutions)
- LeetCode Solutions : Rotate List
- 【LeetCode】145. Binary Tree Postorder Traversal (3 solutions)
- 【LeetCode】162. Find Peak Element (3 solutions)
- 【LeetCode】40. Combination Sum II (2 solutions)
- 【LeetCode】25. Reverse Nodes in k-Group (2 solutions)
- 【LeetCode】207. Course Schedule (2 solutions)
- 【LeetCode】111. Minimum Depth of Binary Tree (2 solutions)
- 【LeetCode】142. Linked List Cycle II (2 solutions)
- 【LeetCode】338. Counting Bits (2 solutions)
- 【LeetCode】48. Rotate Image (2 solutions)
- 【LeetCode】206. Reverse Linked List (2 solutions)
- 【LeetCode】102. Binary Tree Level Order Traversal (2 solutions)
- 【LeetCode】75. Sort Colors (3 solutions)