首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

算法与数据结构(三) 二叉树的遍历及其线索化(Swift版)

前面两篇博客介绍了线性表的顺序存储与链式存储以及对应的操作,并且还聊了栈与队列的相关内容。本篇博客我们就继续聊数据结构的相关东西,并且所涉及的相关Demo依然使用面向对象语言Swift来表示。本篇博客我们就来介绍树结构的一种:二叉树。在之前的博客中我们简单的聊了一点树的东西,树结构的特点是除头节点以外的节点只有一个前驱,但是可以有一个或者多个后继。而二叉树的特点是除头结点外的其他节点只有一个前驱,节点的后继不能超过2个。 本篇博客,我们只对二叉树进行讨论。在本篇博客中,我们对二叉树进行创建,然后进行各种遍历

010

二叉树入门就是这么简单!

自知技术有限,不过凭借着对编程的喜爱与兴趣,坚持发表一些文章,或在大神眼中,确实微不足道,也或许能给一些朋友一些启发,由于个人技术的不足,或许文章中会出现一些不足或错误之处,非常感谢大家能不吝指出,坚持写作大半年了,虽说没有什么显著的成就,但是一篇篇文章也给了我满满的记忆,作为一名普通本科的在校学生,每天坚持写一些东西,去做图,去写代码,去看一些书籍,找一些资料,帮助自己理解,再想想如何用自己的语言总结,归纳一下。技术的局限,有时候总会遇到一些盲区,写出来的文章,总是过于叙事化,理论化,缺乏实际经验,本地所模拟的一些例子,可能并不是很合理,也没有那么使用,但我也在尽量的弥补与实际开发应用的距离,总而言之,感谢各位支持,也感谢帮助过我的一个人。

02

线索二叉树

在二叉树的结点上加上线索的二叉树称为线索二叉树,对二叉树以某种遍历方式(如先序、中序、后序或层次等)进行遍历,使其变为线索二叉树的过程称为对二叉树进行线索化。 对于n个结点的二叉树,在二叉链存储结构中有n+1个空链域,利用这些空链域存放在某种遍历次序下该结点的前驱结点和后继结点的指针,这些指针称为线索,加上线索的二叉树称为线索二叉树。 这种加上了线索的二叉链表称为线索链表,相应的二叉树称为线索二叉树(Threaded BinaryTree)。根据线索性质的不同,线索二叉树可分为前序线索二叉树、中序线索二叉树和后序线索二叉树三种。 注意:线索链表解决了无法直接找到该结点在某种遍历序列中的前驱和后继结点的问题,解决了二叉链表找左、右孩子困难的问题。

02
领券