0

0

c++中如何实现后序遍历_c++二叉树后序遍历方法

尼克

尼克

发布时间:2025-09-26 08:53:02

|

826人浏览过

|

来源于php中文网

原创

答案是:C++中二叉树后序遍历有递归和迭代两种方法,顺序为左→右→根,递归简洁但可能栈溢出,迭代用栈模拟,适合深树。

c++中如何实现后序遍历_c++二叉树后序遍历方法

在C++中实现二叉树的后序遍历,主要有两种方法:递归和迭代。后序遍历的顺序是“左子树 → 右子树 → 根节点”,适合用于释放树节点或计算表达式树等场景。

定义二叉树节点结构

在开始前,先定义一个基本的二叉树节点结构:

struct TreeNode {
    int val;
    TreeNode* left;
    TreeNode* right;
    TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
};

方法一:递归实现

递归是最直观的方式,按照“左→右→根”的顺序访问节点。

void postorderTraversalRecursive(TreeNode* root) {
    if (root == nullptr) return;
postorderTraversalRecursive(root->left);  // 遍历左子树
postorderTraversalRecursive(root->right); // 遍历右子树
std::cout << root->val << " ";            // 访问根节点

}

优点是代码简洁易懂,缺点是在树很深时可能引发溢出。

方法二:迭代实现(使用栈)

迭代法用显式栈模拟递归过程。关键点是判断节点是否已经处理过右子树。

一种常见做法是使用一个指针记录上一个访问的节点,避免重复进入右子树:

void postorderTraversalIterative(TreeNode* root) {
    if (root == nullptr) return;
std::stack stack;
TreeNode* lastVisited = nullptr;
TreeNode* current = root;

while (current != nullptr || !stack.empty()) {
    if (current != nullptr) {
        stack.push(current);
        current = current->left;  // 一直向左走
    } else {
        TreeNode* peekNode = stack.top();
        // 如果右子树存在且未被访问过,进入右子树
        if (peekNode->right != nullptr && lastVisited != peekNode->right) {
            current = peekNode->right;
        } else {
            std::cout << peekNode->val << " ";
            lastVisited = stack.top();
            stack.pop();
        }
    }
}

}

这种方法空间复杂度为O(h),h为树的高度,适合深度较大的树。

测试示例

你可以这样测试上述代码:

Teleporthq
Teleporthq

一体化AI网站生成器,能够快速设计和部署静态网站

下载

int main() {
    TreeNode* root = new TreeNode(1);
    root->right = new TreeNode(2);
    root->right->left = new TreeNode(3);
std::cout << "后序遍历结果: ";
postorderTraversalRecursive(root); // 输出: 3 2 1
std::cout << std::endl;

return 0;

}

基本上就这些。递归写起来快,迭代更安全。根据实际需求选择合适的方法即可。

立即学习C++免费学习笔记(深入)”;

相关文章

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

392

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

572

2023.08.10

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

19

2026.01.20

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

61

2026.01.19

java用途介绍
java用途介绍

本专题整合了java用途功能相关介绍,阅读专题下面的文章了解更多详细内容。

87

2026.01.19

java输出数组相关教程
java输出数组相关教程

本专题整合了java输出数组相关教程,阅读专题下面的文章了解更多详细内容。

39

2026.01.19

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

10

2026.01.19

xml格式相关教程
xml格式相关教程

本专题整合了xml格式相关教程汇总,阅读专题下面的文章了解更多详细内容。

13

2026.01.19

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

19

2026.01.19

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
HTML5/CSS3/JavaScript/ES6入门课程
HTML5/CSS3/JavaScript/ES6入门课程

共102课时 | 6.8万人学习

前端基础到实战(HTML5+CSS3+ES6+NPM)
前端基础到实战(HTML5+CSS3+ES6+NPM)

共162课时 | 18.9万人学习

第二十二期_前端开发
第二十二期_前端开发

共119课时 | 12.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号