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

使用场景

后序遍历常用于:

  • 删除或释放二叉树
  • 后序表达式的求值
  • 计算二叉树的高度
相关推荐
还有糕手30 分钟前
算法【有依赖的背包】
算法·动态规划
pursuit_csdn1 小时前
力扣 347. 前 K 个高频元素
算法·leetcode
wen__xvn1 小时前
每日一题洛谷B3865 [GESP202309 二级] 小杨的 X 字矩阵c++
c++·算法·矩阵
makabaka_T_T1 小时前
25寒假算法刷题 | Day1 | LeetCode 240. 搜索二维矩阵 II,148. 排序链表
数据结构·c++·算法·leetcode·链表·矩阵
辞半夏丶北笙2 小时前
最近最少使用算法(LRU最近最少使用)缓存替换算法
java·算法·缓存
BingLin-Liu2 小时前
蓝桥杯备考:六大排序算法
算法·排序算法
南玖yy2 小时前
C语言:数组的介绍与使用
c语言·开发语言·算法
小菜鸟博士2 小时前
手撕Vision Transformer -- Day1 -- 基础原理
人工智能·深度学习·学习·算法·面试
灰灰老师3 小时前
数据分析系列--[11] RapidMiner,K-Means聚类分析(含数据集)
人工智能·算法·机器学习·数据挖掘·数据分析·kmeans·rapidminer
追求源于热爱!4 小时前
记4(可训练对象+自动求导机制+波士顿房价回归预测
图像处理·人工智能·算法·机器学习·回归