自学数据结构已经很久了,使用的教材是《数据结构与算法分析——C语言描述》。现在回过头来再看一遍此书,重新梳理一下数据结构的相关知识。
以下是摘自维基百科的一些树的基本分类:
表达式树:树叶是操作数,如常量或变量。其他的节点是操作符。
二叉查找树:对于树中的每个节点X,它的左子树中所有关键字值小于X的关键字值,它的右子树中所有关键字值大于X的关键字值。
AVL树:每个节点的左子树和右子树的高度最多差1的二叉查找树。
伸展树:它保证从空树开始任意连续M次对树的操作最多花费O(M*logN)时间。
B-树(引自百度百科):一棵m阶B树(balanced tree of order m)是一棵平衡的m路搜索树。它或者是空树,或者是满足下列性质的树:
Trie树:又称单词查找树,字典树。根节点不包含字符,除根节点外每一个节点都只包含一个字符; 从根节点到某一节点,路径上经过的字符连接起来,为该节点对应的字符串; 每个节点的所有子节点包含的字符都不相同。(在刷ACM题学习到的)
关于三种遍历树的方法做一个简单的总结:
先序遍历(前缀表达式):打印顺序:节点、左子树、右子树。
中序遍历(中缀表达式):打印顺序:左子树、节点、右子树。
后序遍历(后缀表达式):打印顺序:左子树、右子树、节点。
原文地址:http://blog.csdn.net/u010275850/article/details/44730373