二叉树 (Binary Tree) 三种存储结构及四种遍历:先根

2019-04-18  本文已影响0人  entro

Binary Tree 三种存储结构及四种遍历:先根、中根、后根、层序

一、二叉树的分类:

B树和B+树是一种多叉树。

二、三种表示结构

2.1 顺序存储

一个存储在数组中的完全二叉树

顺序存储的缺点在非满二叉树的情况下浪费空间,例如极端情况深度为h的二叉树每个节点都只有右孩子,该结构需要占用2^h-1的空间,实际却占用了h个节点。

String[] arrayBinaryTree = {"A", "B", "C", "D", "E", "F", "G", "#", "I"};

2.2 二叉链表存储 只包含对左右子节点的连接指针

class BinaryLinkedListBinaryTree {
    private String data;
    private BinaryLinkedListBinaryTree leftChild = null;
    private BinaryLinkedListBinaryTree rightChild = null;
    //…
    }

2.3 三叉链表存储 节点包含对父节点和左右子节点的指针

改进于二叉链表,增加父节点的指引,能更好地实现节点间的访问

public class TripleLinkedListBinaryTree {

    private String data;
    private TripleLinkedListBinaryTree fatherNode = null;
    private TripleLinkedListBinaryTree leftChild = null;
    private TripleLinkedListBinaryTree rightChild = null;
    //…
    }

三、几种遍历(traversal)方式:前序、中序、后序、层序

针对前序遍历、中序遍历、后序遍历,先左和先右的效率是一样的,按照习惯,我们碰到左右排序的时候一般都采用先左边后右边。

3.1 前序遍历

又称先根遍历,按照 ROOT-LEFT-RIGHT 来遍历.
针对一颗顺序存储的平衡二叉树:{"A", "B", "C", "D", "E", "F", "G", "#", "I"}
其先根遍历结果是:A B D I E C F G

3.2 中序遍历

又称中根遍历,遍历顺序: LEFT-ROOT-RIGHT
对应前根遍历的二叉树,中根遍历结果是:D I B E A F C G

3.3 后续遍历

又称后根遍历,遍历顺序: LEFT-RIGHT-ROOT
对应前面的平衡二叉树,其后根遍历结果:I D E B F G C A

3.4 层序遍历

一层一层的遍历,结果是:A B C D E F G I

其他:图的搜索 深度优先 Depth-First-Search 广度优先 Breadth-First-Search

上一篇 下一篇

猜你喜欢

热点阅读