二叉树的遍历是数据结构中非常基础的内容了,今天这一篇文章我们来详细了解一下二叉树的前序遍历,二叉树的前序遍历顺序是根节点-左子树-右子树,本文对递归和栈模拟的方法都有实现
一、递归方法
递归方法可以说是很简了,我们秉承先去往左节点再去往右节点的原则就好了
// assume that we have TreeNode, and res is to store the answer
void preorder(TreeNode *root, vector<int> &res) {
if (root == nullptr) {
return;
}
res.push_back(root->val); // we will record every node we have traveled
preorder(root->left, res); // to left first
preorder(root->right, res); // to right
}
//main
vector<int> preorderTraversal(TreeNode *root) {
vector<int> res;
preorder(root, res);
return res;
}
二、栈实现
我们使用栈迭代来模拟递归的过程,事实上,递归的过程隐式地维护了一个栈,(递归储存了状态,当return 的时候相当于状态集合的.pop() )