C/C++ BM25二叉树的后序遍历

文章目录

前言

和前序遍历中序遍历一致,换个顺序就行。

详情参考C/C++ BM23 二叉树的前序遍历

详情参考C/C++ BM24 二叉树的中序遍历


题目

给定一个二叉树,返回他的后序遍历的序列。

后序遍历是值按照 左节点->右节点->根节点 的顺序的遍历。

数据范围:二叉树的节点数量满足 1 ≤ n ≤ 100 1≤n≤100 1≤n≤100,二叉树节点的值满足 1 ≤ v a l ≤ 100 1≤val≤100 1≤val≤100,树的各节点的值各不相同

输入:

{ 1 , # , 2 , 3 } \{1,\#,2,3\} {1,#,2,3}

返回值:

3 , 2 , 1 \] \[3,2,1\] \[3,2,1

输入:

{ 1 } \{1\} {1}

返回值:

1 \] \[1\] \[1

解决方案一

1.1 思路阐述

后序遍历是是什么:

一棵树有根节点,根节点下面有左子树和右子树。左子树和右子树的根节点为这棵树根节点的左节点和右节点。

后序遍历的意思就是,左右根。先遍历左子树和右子树再遍历根节点。

1.2 源码

cpp 复制代码
/**
 * struct TreeNode {
 *	int val;
 *	struct TreeNode *left;
 *	struct TreeNode *right;
 *	TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 * };
 */
class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param root TreeNode类 
     * @return int整型vector
     */
    vector<int> temp;
    vector<int> postorderTraversal(TreeNode* root) {
        if(!root)//如果节点为空,则返回原数组
            return temp;
        postorderTraversal(root->left);//遍历当前子树的左节点
        postorderTraversal(root->right);//遍历当前子树的右节点
        temp.push_back(root->val);//不为空则表示遍历到这个节点,将这个节点的值添加到数组中
        return temp;

    }
};

解决方案二

这个我就不贴了,都一样的。顶多就是把函数功能单独拎出来。

总结

明白了前序和中序遍历,这个后序遍历也非常简单。

相关推荐
艾莉丝努力练剑10 小时前
【C++:C++11】C++11新特性深度解析:从可变参数模板到Lambda表达式
c++·stl·c++11·lambda·可变模版参数
叫致寒吧11 小时前
Tomcat详解
java·tomcat
同学小张12 小时前
【端侧AI 与 C++】1. llama.cpp源码编译与本地运行
开发语言·c++·aigc·llama·agi·ai-native
S***267515 小时前
基于SpringBoot和Leaflet的行政区划地图掩膜效果实战
java·spring boot·后端
Yue丶越15 小时前
【C语言】字符函数和字符串函数
c语言·开发语言·算法
马剑威(威哥爱编程)15 小时前
鸿蒙6开发视频播放器的屏幕方向适配问题
java·音视频·harmonyos
JIngJaneIL15 小时前
社区互助|社区交易|基于springboot+vue的社区互助交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·社区互助
V***u45316 小时前
MS SQL Server partition by 函数实战二 编排考场人员
java·服务器·开发语言
这是程序猿16 小时前
基于java的ssm框架旅游在线平台
java·开发语言·spring boot·spring·旅游·旅游在线平台
爱学习的小邓同学16 小时前
C++ --- 多态
开发语言·c++