题目描述
给定一个二叉树,返回它的 后序 遍历。
示例:
输入: [1,null,2,3]
1
\
2
/
3
输出: [3,2,1]
进阶: 递归算法很简单,你可以通过迭代算法完成吗?
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/binary-tree-postorder-traversal
解题思路
使用后续遍历的模板
后续遍历访问顺序:左->右->根
1.如果当前结点为空结点,就return
2.先后续遍历左子树
3.再后续遍历右子树
4.再访问当前结点,并且把当前结点放到res中。就完成了左->右->根的顺序
代码
/**
* 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) {}
* };
*/
class Solution {
public:
void posOrder(TreeNode* root ,vector<int> &res){
if(root==NULL){ //如果当前结点为空
return; //直接返回
}
posOrder(root->left, res); //后续遍历左子树
posOrder(root->right, res); //后续遍历右子树
res.push_back(root->val); //将当前结点放入res中
}
vector<int> postorderTraversal(TreeNode* root) {
vector<int> res; //定义res用来存储最终结果
if(root==NULL){ //如果题目中给的是空树,就直接return 空的res
return res;
}
posOrder(root, res); //否则对这个树进行后续遍历,并且把结果存入res中
return res; //返回res结果
}
};
本文讲解了如何通过递归和迭代的方式实现二叉树的后序遍历,提供了解题思路、代码示例,并探讨了从空树到实际操作的详细步骤。适合理解二叉树遍历算法的进阶学习者。
580

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



