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从根节点开始进行后序遍历。
    • 最后返回结果向量。

使用场景

后序遍历常用于:

  • 删除或释放二叉树
  • 后序表达式的求值
  • 计算二叉树的高度
相关推荐
UFIT6 分钟前
NoSQL之redis哨兵
java·前端·算法
喜欢吃燃面7 分钟前
C++刷题:日期模拟(1)
c++·学习·算法
SHERlocked9310 分钟前
CPP 从 0 到 1 完成一个支持 future/promise 的 Windows 异步串口通信库
c++·算法·promise
怀旧,16 分钟前
【数据结构】6. 时间与空间复杂度
java·数据结构·算法
积极向上的向日葵29 分钟前
有效的括号题解
数据结构·算法·
GIS小天35 分钟前
AI+预测3D新模型百十个定位预测+胆码预测+去和尾2025年6月7日第101弹
人工智能·算法·机器学习·彩票
_Itachi__1 小时前
LeetCode 热题 100 74. 搜索二维矩阵
算法·leetcode·矩阵
不忘不弃1 小时前
计算矩阵A和B的乘积
线性代数·算法·矩阵
不爱写代码的玉子1 小时前
HALCON透视矩阵
人工智能·深度学习·线性代数·算法·计算机视觉·矩阵·c#
Java 技术轻分享1 小时前
《树数据结构解析:核心概念、类型特性、应用场景及选择策略》
数据结构·算法·二叉树··都差速