| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> 二叉树深度优先遍历(递归和非递归c++) -> 正文阅读 |
|
[数据结构与算法]二叉树深度优先遍历(递归和非递归c++) |
深度优先遍历的三种方式: ? 中序遍历,前序遍历, 后序遍历 中序遍历: 先遍历最左边的叶节点,然后遍历其根节点,再去遍历右节点. 在图中,从1开始,往左下方2,往左下方4.这时候空了,所以回到2,再去2的右边,到5,到7,回到5,到8,这时候回到1,再去3,去6 所以顺序为: 4 ->2 ->7 ->5 ->8 ->1 ->3 ->6 递归的实现,有递归和非递归/迭代的两种方式,其中,迭代的方式相对简单,因为其实遍历的过程,就是左边中间右边的重复顺序,所以,想到用递归的思路还是很直接的. c++代码如下
如果不采用递归的思路,而是迭代的思路,那么,我们就要去维护一个数据结构,来存储遍历到的节点,这里思考一下我们对于这个数据结构的需求,在从根节点的遍历过程中,一旦我们访问到左节点,我们就应该把它放到这个数据结构中,这里考虑到用stack的数据结构,因为后遍历到的应该首先被存进去. 此外,中序遍历迭代方法的难点在于, 我们将一个元素存入stack,和我们调用它,是两个步骤,比如根节点在最开始就被存储了,但实际上,他是在后面才被调用,因此实现起来会感到不适. 我们要思考几个问题 1. 什么时候把节点存入stack,nullptr该怎么处理 2. 什么时候去遍历右边 3.什么时候把右边的元素存进去 二叉树的迭代中序遍历实现
完全二叉树的判断 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/25 21:14:43- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |