当前位置: 首页 > news >正文

刷题——二叉树的后续遍历

方法一:双指针法

 void  postorder(TreeNode* root, vector<int>&res){if(root == NULL) return;postorder(root->left,res);postorder(root->right,res);res.push_back(root->val);}vector<int> postorderTraversal(TreeNode* root) {// write code herevector<int>res;postorder(root, res);return res;}

方法二:入栈出栈法

vector<int> postorderTraversal(TreeNode* root) {vector<int> res;stack<TreeNode*> s;TreeNode* prev = nullptr; // 用于跟踪上一个访问的节点while (root != nullptr || !s.empty()) {while (root != nullptr) {s.push(root);root = root->left; // 先尽可能遍历到最左边}root = s.top(); // 获取当前栈顶元素(最深的未完全访问的节点)// 检查是否可以访问当前节点(即其右子树已访问或无右子树)if (root->right == nullptr || root->right == prev) {res.push_back(root->val); // 访问当前节点prev = root; // 更新prev为当前节点,表示其左右子树均已处理s.pop(); // 弹出当前节点,准备处理下一个root = nullptr; // 重置root,将在下次循环中从栈中获取新的节点} else {// 如果当前节点的右子树还未访问,则转向访问右子树root = root->right;}}return res;
}

http://www.lryc.cn/news/384161.html

相关文章:

  • 用友U8 Cloud smartweb2.showRPCLoadingTip.d XXE漏洞复现
  • React中的事件绑定的四种方式
  • 小文件过多的解决方法(不同阶段下的治理手段,SQL端、存储端以及计算端)
  • SGPT论文阅读笔记
  • 虚拟机与主机的网络桥接
  • urfread刷算法题day1|LeetCode2748.美丽下标的数目
  • 面向对象修炼手册(四)(多态与空间分配)(Java宝典)
  • 基于UDP的网络聊天室(多线程实现收和发消息)
  • 【脚本工具库】随机抽取数据 - 图像和标签对应(附源码)
  • 【python】eval函数
  • 实战|记一次java协同办公OA系统源码审计
  • 浅浅谈谈如何利用Javase+多线程+计算机网络的知识做一个爬CSDN阅读量总访问量的程序
  • Vscode 中launch.json与tasks.json文件
  • C#基于SkiaSharp实现印章管理(2)
  • 大二C++期末复习(自用)
  • 重大进展!微信支付收款码全场景接入银联网络
  • msvcr110.dll丢失的解决方法,亲测有效的几种解决方法
  • SUSE Linux 15 sp5上Nginx安装配置升级
  • 突破Web3红海,DePIN如何构建创新生态系统?
  • 裸机与操做系统区别(RTOS)
  • 详解 ClickHouse 的分片集群
  • AI问答-医疗:什么是“手术报台”
  • S-Clustr(影子集群)V3 高并发,去中心化,多节点控制
  • 支持WebDav的网盘infiniCloud(静读天下,Zotero 等挂载)
  • Linux命令行导出MySQL数据库备份并压缩
  • 二叉树的广度优先搜索(层次遍历)
  • AU音频重新混合音频,在 Adobe Audition 中无缝延长背景音乐,无缝缩短BGM
  • 11-Django项目--Ajax请求二
  • 代码评审——Java占位符%n的处理
  • 超低排放标准