数据结构:3.3.3层序遍历

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

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

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

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

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

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

算法实现:

相关推荐
倔强的石头_23 分钟前
【数据结构与算法 经典例题】使用队列实现栈(图文详解)
后端·算法
黑色的山岗在沉睡41 分钟前
P1216 [IOI 1994] 数字三角形 Number Triangles
算法·动态规划
与己斗其乐无穷1 小时前
数据结构(9)排序
数据结构
青山是哪个青山1 小时前
递归,回溯,DFS,Floodfill,记忆化搜索
算法·深度优先
一块plus1 小时前
参与、拥有、共创:Web3 游戏开启玩家共建时代
算法·程序员·架构
倔强的石头_2 小时前
【数据结构与算法】插入排序:原理、实现与分析
算法
倔强的石头_2 小时前
【数据结构与算法】希尔排序:基于插入排序的高效排序算法
后端·算法
Shaun_青璇2 小时前
CPP基础(2)
开发语言·c++·算法
红糖生姜3 小时前
字符串|数组|计算常见函数整理-竞赛专用(从比赛真题中总结的,持续更新中)
c++·算法
NULL指向我3 小时前
C语言数据结构笔记6:使用宏和指针来设置和操作嵌套在结构体中的联合体数组的特定位
c语言·数据结构·笔记