150.二叉树:二叉树的后序遍历(力扣)

代码解决

cpp 复制代码
/**
 * 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 traversal(TreeNode* tree, vector<int>& res) {
        if(tree == NULL) return;  // 如果节点为空,则直接返回

        traversal(tree->left, res);   // 递归遍历左子树
        traversal(tree->right, res);  // 递归遍历右子树
        res.push_back(tree->val);     // 访问根节点,将节点值加入结果向量
    }

    // 后序遍历的主函数
    vector<int> postorderTraversal(TreeNode* root) {
        vector<int> result;           // 存储遍历结果的向量
        traversal(root, result);      // 调用递归函数进行后序遍历
        return result;                // 返回结果向量
    }
};

详细解释

  1. TreeNode 结构体

    • 定义了一个二叉树节点结构体TreeNode,包括节点的值val,左子节点指针left,和右子节点指针right
    • 提供了三种构造函数:
      • 默认构造函数初始化节点值为0,左右子节点为空。
      • 带一个整数参数的构造函数初始化节点值为给定值,左右子节点为空。
      • 带一个整数和两个子节点参数的构造函数初始化节点值和左右子节点。
  2. Solution 类

    • 包含后序遍历二叉树的实现。
  3. traversal 函数

    • 这是一个递归函数,用于执行后序遍历。
    • 参数tree是当前节点,res是存储遍历结果的向量。
    • 首先检查当前节点是否为空,如果为空,则返回。
    • 递归遍历左子树和右子树。
    • 最后将当前节点的值加入结果向量。
  4. postorderTraversal 函数

    • 这是后序遍历的主函数。
    • 创建一个空的结果向量result
    • 调用递归函数traversal从根节点开始进行后序遍历。
    • 最后返回结果向量。

使用场景

后序遍历常用于:

  • 删除或释放二叉树
  • 后序表达式的求值
  • 计算二叉树的高度
相关推荐
薰衣草233312 分钟前
hot100练习-11
算法·leetcode
地平线开发者37 分钟前
征程 6 | 工具链如何支持 Matmul/Conv 双 int16 输入量化?
人工智能·算法·自动驾驶
甄心爱学习41 分钟前
数值计算-线性方程组的迭代解法
算法
stolentime1 小时前
SCP2025T2:P14254 分割(divide) 题解
算法·图论·组合计数·洛谷scp2025
Q741_1471 小时前
C++ 面试基础考点 模拟题 力扣 38. 外观数列 题解 每日一题
c++·算法·leetcode·面试·模拟
W_chuanqi1 小时前
RDEx:一种效果驱动的混合单目标优化器,自适应选择与融合多种算子与策略
人工智能·算法·机器学习·性能优化
L_09072 小时前
【Algorithm】二分查找算法
c++·算法·leetcode
靠近彗星2 小时前
3.3栈与队列的应用
数据结构·算法
Han.miracle6 小时前
数据结构——二叉树的从前序与中序遍历序列构造二叉树
java·数据结构·学习·算法·leetcode
mit6.8248 小时前
前后缀分解
算法