代码随想录 二叉树 test 2
二叉树的非递归遍历
先序
方法一:
先保存根节点,用来之后找到右子树(利用栈来回溯到根,进而找到右子树)
class Solution {
public:vector<int> preorderTraversal(TreeNode* root) {vector<int> res; //存遍历序列stack<TreeNode*> stk;TreeNode* p = root;while(p || !stk.empty()){if(p != nullptr){ res.push_back(p->val); //访问根节点stk.push(p);p = p->left; //移动到左子树}else{ //如果左子树为空,就需要访问上一个结点的右子树p = stk.top();stk.pop();p = p->right;}}return res;}
};
方法二:
不用回溯,利用栈的先进后出性质,先将右子树入栈,再将左子树入栈,实现根左右。
class Solution {
public:vector<int> preorderTraversal(TreeNode* root) {if(!root) return {};vector<int> res; //存遍历序列stack<TreeNode*> stk;stk.push(root);while(!stk.empty()){TreeNode* p = stk.top();stk.pop();res.push_back(p->val); //根if(p->right) stk.push(p->right); //将非空的右孩子压栈if(p->left) stk.push(p->left); //将非空的左孩子压栈}return res;}
};
方法三:统一迭代法
每次以根节点为处理对象,如果当前遍历的结点非空,则按照右左根顺序,将三个结点都压入栈中,在压入根节点之后继续压入空指针,因此处理顺序与出栈顺序对应。如果为空,则当前该结点需要输出。
class Solution {
public:vector<int> preorderTraversal(TreeNode* root) {vector<int> res; //存遍历序列if(!root) return res;stack<TreeNode*> stk;stk.push(root);while(!stk.empty()){TreeNode* p = stk.top();if(p != nullptr){stk.pop();if(p->right) stk.push(p->right); //右if(p->left) stk.push(p->left); //左stk.push(p); //中stk.push(nullptr); //标记在空结点之下即为要处理的结点}else{stk.pop(); //弹出空结点p = stk.top(); //访问要处理的结点stk.pop(); //弹出已处理好的结点res.push_back(p->val);}}return res;}
};
中序
方法一
与先序方法一类似,将访问结点操作放在遍历到当前最左结点之后。
class Solution {
public:vector<int> inorderTraversal(TreeNode* root) {vector<int> res; //存遍历序列stack<TreeNode*> stk;TreeNode* p = root;while(p || !stk.empty()){if(p != nullptr){ stk.push(p);p = p->left; //移动到左子树}else{ //如果左子树为空,就需要访问上一个结点的右子树p = stk.top();stk.pop();res.push_back(p->val); //访问左p = p->right;}}return res;}
};
方法二:统一迭代法
只需将先序中的统一迭代法,按照右根左入栈即可。
class Solution {
public:vector<int> inorderTraversal(TreeNode* root) {vector<int> res; //存遍历序列if(!root) return res;stack<TreeNode*> stk;stk.push(root);while(!stk.empty()){TreeNode* p = stk.top();if(p != nullptr){stk.pop();if(p->right) stk.push(p->right); //右stk.push(p); //中stk.push(nullptr); //标记在空结点之下即为要处理的结点if(p->left) stk.push(p->left); //左}else{stk.pop(); //弹出空结点p = stk.top(); //访问要处理的结点stk.pop(); //弹出已处理好的结点res.push_back(p->val);}}return res;}
};
后序
方法一
改写先序方法一,由于遍历顺序要求是左右根,因此回溯的情况既可能是遍历完左子树也可能是遍历完右子树。如果是遍历完左子树且有右子树且右子树未被遍历过,则需要继续遍历右子树,如果是遍历完右子树,则此时栈顶元素即为当前最右,需要进行处理,处理完最右结点需要回溯到根,因此需要将当前指针置为空,在下一次循环就可以取出栈顶根。由上可知需要标记结点是否被遍历过,因此需要一个指针r记录上一个遍历过的结点。
class Solution {
public:vector<int> postorderTraversal(TreeNode* root) {vector<int> res; //存遍历序列stack<TreeNode*> stk;TreeNode* p = root;TreeNode* r = nullptr;while(p || !stk.empty()){if(p != nullptr){ stk.push(p);p = p->left; //移动到左子树}else{ //如果左子树为空,就需要检查右子树状态p = stk.top();if(p->right && r != p->right){ //如果有右子树且未被遍历过p = p->right;}else{ //否则应该处理栈顶元素p = stk.top();stk.pop();res.push_back(p->val); //处理栈顶r = p; //标记此结点已被处理p = nullptr;}}}return res;}
};
方法二:改写先序方法二+反转
先序方法二颠倒左右子树入栈顺序实现根右左,再进行反转,变成左右根。
class Solution {
public:vector<int> postorderTraversal(TreeNode* root) {if(!root) return {};vector<int> res; //存遍历序列stack<TreeNode*> stk;stk.push(root);while(!stk.empty()){TreeNode* p = stk.top();stk.pop();res.push_back(p->val); //根if(p->left) stk.push(p->left); //将非空的左孩子压栈if(p->right) stk.push(p->right); //将非空的右孩子压栈}reverse(res.begin(), res.end()); //反转数组return res;}
};
方法三:统一迭代法
按照根右左顺序入栈
class Solution {
public:vector<int> postorderTraversal(TreeNode* root) {vector<int> res; //存遍历序列if(!root) return res;stack<TreeNode*> stk;stk.push(root);while(!stk.empty()){TreeNode* p = stk.top();if(p != nullptr){stk.pop();stk.push(p); //中stk.push(nullptr); //标记在空结点之下即为要处理的结点if(p->right) stk.push(p->right); //右if(p->left) stk.push(p->left); //左}else{stk.pop(); //弹出空结点p = stk.top(); //访问要处理的结点stk.pop(); //弹出已处理好的结点res.push_back(p->val);}}return res;}
};
相关文章:
代码随想录 二叉树 test 2
二叉树的非递归遍历 先序 方法一: 先保存根节点,用来之后找到右子树(利用栈来回溯到根,进而找到右子树) class Solution { public:vector<int> preorderTraversal(TreeNode* root) {vector<int> res; //存遍历序列stack<TreeNode*…...
浏览器默认语言与页面访问统计问题二三则
文章目录 前言网站默认语言问题网站访问统计问题Error: Empty components are self-closingError: A space is required before closing bracket 总结 前言 看标题大概能猜到这是一篇杂合体的总结,是这两天处理网站遇到的小问题,怕过段时间再忘了所以总…...
用Python绘制一只懒羊羊
目录 一、准备工作 二、Turtle库简介 三、绘制懒羊羊的步骤 1. 导入Turtle库并设置画布 2. 绘制头部 3. 绘制眼睛 4. 绘制嘴巴 5. 绘制身体 6. 绘制四肢 7. 完成绘制 五、运行代码与结果展示 六、总结 在这个趣味盎然的技术实践中,我们将使用Python和Turtle图形…...
虹科分享 | 汽车NVH小课堂之听音辨故障
随着车主开始关注汽车抖动异响问题,如何根据故障现象快速诊断异响来源,成了汽修人的必修课。 一个比较常用的方法就是靠“听”——“听音辨故障”。那今天,虹科Pico也整理了几个不同类型的异响声音,一起来听听看你能答对几个吧 汽…...
论文速读|SigLIP:Sigmoid Loss for Language Image Pre-Training.ICCV23
论文地址:https://arxiv.org/abs/2303.15343v4 代码地址:https://github.com/google-research/big_vision bib引用: misc{zhai2023sigmoidlosslanguageimage,title{Sigmoid Loss for Language Image Pre-Training}, author{Xiaohua Zhai and…...
深度学习笔记——循环神经网络之LSTM
大家好,这里是好评笔记,公主号:Goodnote,专栏文章私信限时Free。本文详细介绍面试过程中可能遇到的循环神经网络LSTM知识点。 文章目录 文本特征提取的方法1. 基础方法1.1 词袋模型(Bag of Words, BOW)工作…...
算法整理:2-opt求解旅行商(Python代码)
文章目录 算法思想算法步骤代码1纯函数代码2纯函数数据可视化 算法思想 通过交换边进行寻优。 算法步骤 把初始解作为当前解 通过交换边生成新解 如果新解优于历史最优解,则更新当前解为新解 重复2,3,直到当前解交换了所有的边均不能改…...
状态模式
在软件开发过程中,我们经常会遇到这样的情况:一个对象的行为会随着其内部状态的改变而发生变化。例如,一个手机在不同状态下(开机、关机、静音等)对相同的操作(如来电)会有不同的反应。传统的解…...
RoHS 简介
RoHS(Restriction of Hazardous Substances Directive,限制有害物质指令)是欧盟制定的一项环保法规,旨在限制电气和电子设备中某些有害物质的使用,以减少这些产品对环境和人体健康的危害。 RoHS限制的有害物质及其限量…...
【Vim Masterclass 笔记26】S11L46:Vim 插件的安装、使用与日常管理
文章目录 Section 11:Vim PluginsS11L46 Managing Vim Plugins1 第三方插件管理工具2 安装插件使用的搜索引擎3 Vim 插件的安装方法4 存放 Vim 插件包的路径格式5 示例一:插件 NERDTree 的安装6 示例二:插件 ctrlp.vim 的安装7 示例三&#x…...
深度学习原理与Pytorch实战
深度学习原理与Pytorch实战 第2版 强化学习人工智能神经网络书籍 python动手学深度学习框架书 TransformerBERT图神经网络: 技术讲解 编辑推荐 1.基于PyTorch新版本,涵盖深度学习基础知识和前沿技术,由浅入深,通俗易懂…...
ELK环境搭建
文章目录 1.ElasticSearch安装1.安装的版本选择1.SpringBoot版本:2.4.2 找到依赖的spring-data-elasticsearch的版本2.spring-data-elasticsearch版本:4.1.3 找到依赖的elasticsearch版本3.elasticsearch版本:7.9.3 2.安装1.官方文档2.下载压…...
基于Springboot + vue实现的民俗网
“前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站:人工智能学习网站” 💖学习知识需费心, 📕整理归纳更费神。 🎉源码免费人人喜…...
第24篇 基于ARM A9处理器用汇编语言实现中断<六>
Q:怎样设计ARM处理器汇编语言程序使用定时器中断实现实时时钟? A:此前我们曾使用轮询定时器I/O的方式实现实时时钟,而在本实验中将采用定时器中断的方式。新增第三个中断源A9 Private Timer,对该定时器进行配置&#…...
【数据结构】_不带头非循环单向链表
目录 1. 链表的概念及结构 2. 链表的分类 3. 单链表的实现 3.1 SList.h头文件 3.2 SList.c源文件 3.3 Test_SList.c测试文件 关于线性表,已介绍顺序表,详见下文: 【数据结构】_顺序表-CSDN博客 本文介绍链表; 基于顺序表…...
golang 使用双向链表作为container/heap的载体
MyHeap:container/heap的数据载体,需要实现以下方法: Len:堆中数据个数 Less:第i个元素 是否必 第j个元素 值小 Swap:交换第i个元素和 第j个元素 Push:向堆中追加元素 Pop:从堆…...
C#集合操作优化:高效实现批量添加与删除
在C#中,对集合进行批量操作(如批量添加或删除元素)通常涉及使用集合类型提供的方法和特性,以及可能的循环或LINQ查询来高效地处理大量数据。以下是一些常见的方法和技巧: 批量添加元素 使用集合的AddRange方法&#x…...
142.WEB渗透测试-信息收集-小程序、app(13)
免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动! 内容参考于: 易锦网校会员专享课 上一个内容:141.WEB渗透测试-信息收集-小程序、app(12) 软件用法,…...
24.日常算法
1. 数组中两元素的最大乘积 题目来源 给你一个整数数组 nums,请你选择数组的两个不同下标 i 和 j,使 (nums[i]-1)*(nums[j]-1) 取得最大值。请你计算并返回该式的最大值。 示例 1: 输入:nums [3,4,5,2] 输出:12 解释…...
分布式理解
分布式 如何理解分布式 狭义的分布是指,指多台PC在地理位置上分布在不同的地方。 分布式系统 分布式系**统:**多个能独立运行的计算机(称为结点)组成。各个结点利用计算机网络进行信息传递,从而实现共同的“目标或者任…...
Sentinel-3B OLCI 3 级全球分箱地球观测降分辨率(ERR)叶绿素(CHL)数据,版本 2022.0
Sentinel-3B OLCI Level-3 Global Binned Earth-observation Reduced Resolution (ERR) Chlorophyll (CHL) Data, version 2022.0 简介 叶绿素 a 数据集提供全球网格化的表层叶绿素 a 浓度(浮游植物生物量的替代指标)合成数据。CHL 支持时间序列和气候…...
Yokogawa AAI835-H50/K4A00模拟输入/输出模块
Yokogawa AAI835-H50/K4A00 模拟输入/输出模块产品特点:通道配置:共8个通道,含4路模拟输入和4路模拟输出。信号类型:所有通道均支持4-20mA标准电流信号。HART通信:支持HART协议,可与智能现场设备双向数字通…...
C语言双端队列完整实现:一行代码吃透头尾操作,算法效率拉满
一、为什么C语言实现双端队列,是数据结构的必学天花板?在C语言数据结构里,队列、栈都是基础中的基础,但真正能把灵活度、效率、内存管理三者揉到一起的,还得是双端队列(deque)。普通队列只能一头…...
HFSS仿真结果怎么看?一文读懂S参数与电场图,让你的T型波导分析不再迷茫
HFSS仿真结果深度解析:从S参数到电场图的工程实践指南面对HFSS仿真生成的复杂数据图表,许多工程师常陷入"看得见数据却读不懂含义"的困境。本文将带您穿透数据表象,掌握T型波导性能分析的核心方法论。1. S参数:波导性能…...
大佬推荐的网络安全学习路线(从基础到高级,超级详细)
大佬推荐的网络安全学习路线(从基础到高级,超级详细) 说起网络安全,你可能会担心它是一个过时的行业。有人说,网络安全快卷死了,你既要攻又要防,并且随着技术的发展,你还要不断地学…...
账务台账数据
银行里说的 “账务台账数据”,本质就是按会计规则把每笔业务逐笔、分户、分科目记下来的完整明细流水 余额 辅助信息,核心是 “可逐笔追溯、可对账、可审计” 的一套明细数据。下面用通俗、具体的方式拆开说:一、银行 “账务台账” 到底是什…...
论文润色深度测评:GPT-5.5 + Gemini 3.1 Pro:教你学会1+1>2的论文润色方法
各位同仁好,我是七哥。一个在高校里从事人工智能相关领域研究,钻研用大模型AI实操的学术人。可以和七哥交流学术写作或Gemini、GPT、Claude等大模型学术实操相关问题,多多交流,相互成就,共同进步。 2026年的科研圈,AI工具的选择已经从有没有变成了强不强,七哥评测了GPT…...
企业内统一API网关与Taotoken聚合平台对接方案
🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 企业内统一API网关与Taotoken聚合平台对接方案 在推进AI应用落地的过程中,许多中大型企业面临一个共同挑战:…...
defx.nvim 安装与配置完全教程:从零开始搭建高效文件管理系统 [特殊字符]
defx.nvim 安装与配置完全教程:从零开始搭建高效文件管理系统 🚀 【免费下载链接】defx.nvim :file_folder: The dark powered file explorer implementation for neovim/Vim8 项目地址: https://gitcode.com/gh_mirrors/de/defx.nvim defx.nvim …...
yolo视频识别 车辆速度估计识别 yolo11视频实时速度测量与测速估计
文章目录YOLOv11:视频实时速度测量与测速估计一、YOLOv11概述二、速度测量原理三、距离测量方法四、应用场景五、实践案例以下是关于使用YOLOv11进行视频实时速度测量与测速估计的介绍: YOLOv11:视频实时速度测量与测速估计 随着计算机视觉…...
