数据结构:3.3.3层序遍历

二叉树的核心问题:把二维的结构变为一维的线性序列

采用不同的方法就会产生不同的一维的序列

如果不访问父亲结点是访问不到左儿子和右儿子的,如果把父亲忘了左右儿子也是找不到的

二叉树转为一维序列过程中的一个问题:一个结点只关联两个结点,访问了其中的一个另一个怎么办,另一个要把它存起来

用堆栈来保存:自己或者右儿子(在堆栈里实现的是保存自己这个结点)。用堆栈保存的过程:自己访问完了访问左儿子,把自己保存起来,这样将来回来的时候可以去访问右儿子

用队列来保存:保存的是未来要访问的结点(也就是右儿子结点)。

算法实现:

相关推荐
一招定胜负7 分钟前
逻辑回归调优三板斧:参数调整、阈值设定、数据集平衡
算法·机器学习·逻辑回归
豆约翰9 分钟前
Z字形扫描ccf
java·开发语言·算法
Salt_072813 分钟前
DAY 35 文件的规范拆分和写法
python·算法·机器学习
hweiyu0014 分钟前
数据结构:后缀自动机
数据结构
小尧嵌入式15 分钟前
C语言中的面向对象思想
c语言·开发语言·数据结构·c++·单片机·qt
风筝在晴天搁浅18 分钟前
代码随想录 109.冗余连接Ⅱ
算法
业精于勤的牙19 分钟前
浅谈:算法中的斐波那契数(三)
算法·职场和发展
花月C19 分钟前
基于Redis的BitMap数据结构实现签到业务
数据结构·数据库·redis
一杯美式 no sugar22 分钟前
数据结构——单向无头不循环链表
c语言·数据结构·链表
ss27324 分钟前
阻塞队列:三组核心方法全对比
java·数据结构·算法