题目描述:给出一棵二叉树,返回其节点值的前序遍历。
样例:
给出一棵二叉树 {1,#,2,3},
1
\
2
/
3
返回 [1,2,3]
做题思路:用递归算法,从根节点开始,先遍历左子树再遍历右子树,存放在数组中。
关键代码:class Solution {
public:
/**
* @param root: The root of binary tree.
* @return: Preorder in vector which contains node values.
*/
std::vector<int> w;
vector<int> preorderTraversal(TreeNode *root) {
// write your code here
if(root==NULL) return w;
{
w.push_back(root->val);
preorderTraversal(root->left);
preorderTraversal(root->right);
}
return w;
}
};
做题感想:最开始错的是关于vector的定义,因为没有using namespace std ,所以要像代码中那样定义vector,遍历后存入数组,返回数组。
本文介绍了一种使用递归算法实现二叉树节点值的前序遍历方法,并给出了具体的C++代码示例。
741

被折叠的 条评论
为什么被折叠?



