二叉树的前序遍历
2017-04-17 20:58
239 查看
1.问题描述
给出一棵二叉树,返回其节点值的前序遍历。
样例
给出一棵二叉树
返回
2.解题思路
运用递归的思想,按先根在左子树最后右子树的思想将节点存到vector中。
3.代码实现
/**
* Definition of TreeNode:
* class TreeNode {
* public:
* int val;
* TreeNode *left, *right;
* TreeNode(int val) {
* this->val = val;
* this->left = this->right = NULL;
* }
* }
*/
class Solution {
public:
/**
* @param root: The root of binary tree.
* @return: Preorder in vector which contains node values.
*/
vector<int> preorderTraversal(TreeNode *root) {
// write your code here
vector<int>r;
preorder(r,root);
return r;
}
void preorder(vector<int>& r,TreeNode*root)
{
if(root==NULL)
return;
r.push_back(root->val);
preorder(r,root->left);
preorder(r,root->right);
}
};
4.感想
代码中的vector相当于一个全局变量,在整个函数中只定义一次,目的就是所有节点都保存在一个vector 中。
给出一棵二叉树,返回其节点值的前序遍历。
样例
给出一棵二叉树
{1,#,2,3},
1 \ 2 / 3
返回
[1,2,3].
2.解题思路
运用递归的思想,按先根在左子树最后右子树的思想将节点存到vector中。
3.代码实现
/**
* Definition of TreeNode:
* class TreeNode {
* public:
* int val;
* TreeNode *left, *right;
* TreeNode(int val) {
* this->val = val;
* this->left = this->right = NULL;
* }
* }
*/
class Solution {
public:
/**
* @param root: The root of binary tree.
* @return: Preorder in vector which contains node values.
*/
vector<int> preorderTraversal(TreeNode *root) {
// write your code here
vector<int>r;
preorder(r,root);
return r;
}
void preorder(vector<int>& r,TreeNode*root)
{
if(root==NULL)
return;
r.push_back(root->val);
preorder(r,root->left);
preorder(r,root->right);
}
};
4.感想
代码中的vector相当于一个全局变量,在整个函数中只定义一次,目的就是所有节点都保存在一个vector 中。
相关文章推荐
- 二叉树的前序遍历
- leetcode刷题7:前序遍历二叉树
- 由树的前序遍历,中序遍历建立一颗二叉树,并以后续遍历的方式输出其元素
- 二叉树的前序遍历、中序遍历和后序遍历的递归和非递归算法
- LeetCode 根据前序和中序遍历构造二叉树的三种解法
- 已知二叉树的前序遍历,中序遍历,求后序遍历的问题。
- 简单二叉树的构造,前序遍历顺序为;中序遍历顺序为;后序遍历顺序为;
- LintCode:二叉树的前序遍历、中序遍历、后序遍历
- 输入某二叉树的前序和中序遍历结果,重建该二叉树
- [c++]已知二叉树的前序遍历与中序遍历结果(二叉树中不含重复数字),重构二叉树
- 构建二叉树(据前序遍历结果)--- 前序遍历二叉树(递归与非递归)
- 二叉树的遍历规则(前序遍历、后序遍历、中序遍历)
- 根据前序和中序遍历结果重建二叉树
- 面试题 二叉树的前序遍历,中序遍历,后序遍历(递归实现)
- 根据前序和中序遍历输出二叉树
- 已知二叉树后序遍历序列是DBCEFGHA,中序遍历序列EDCBAHFG,它的前序遍历的序列是?麻烦再画下这二叉树.
- lintcode:二叉树的前序遍历
- 题目:二叉树的前序遍历
- LeetCode:Binary Tree Preorder Traversal(非递归方法前序遍历二叉树)
- 二叉树的前序遍历、中序遍历及后序遍历