二叉树的实现及四种常用遍历(python)

构造节点类

二叉树的实现及四种常用遍历(python)_第1张图片

构造树类,并增加添加节点方法

二叉树的实现及四种常用遍历(python)_第2张图片

前序遍历(根,左,右)、中序遍历(左,根,右),后序遍历(左,右,根)

二叉树的实现及四种常用遍历(python)_第3张图片

利用队列实现广度优先遍历,即层次遍历


二叉树的实现及四种常用遍历(python)_第4张图片

[引用]树的遍历主要有两种,一种是深度优先遍历,像前序、中序、后序;另一种是广度优先遍历,像层次遍历。在树结构中两者的区别还不是非常明显,但从树扩展到有向图,到无向图的时候,深度优先搜索和广度优先搜索的效率和作用还是有很大不同的。 
深度优先一般用递归,广度优先一般用队列。一般情况下能用递归实现的算法大部分也能用堆栈来实现。

我印象中是有递归构造树的方法,却一直想不出该怎么构造。后来仔细想了一下,递归思想有点类似深度优先算法,而树的构造应该是广度优先的。如果用递归的话一定要有个终止条件,例如规定树深等。不然构造出来的树会偏向左单子树或者右单子树。所以一般树的构造还是应该用队列比较好。




你可能感兴趣的:(python,数据结构)