索引的数据结构主要有以下几种:
(1)生成索引,建立二叉查找树/二叉排序树/二叉搜索树进行二分查找;
(2)平衡二叉树,红黑树;
(3)生成索引,建立B-Tree(B树/B-树)结构进行查找;
(4)生成索引,建立B+ - Tree(B+树)结构进行查找;
(5)生成索引,建立Hash结构进行查找;
(6)生成索引,建立位图结构进行查找。
1、 二叉查找树
二叉查找树的特点:
(1)二叉查找树的每一个节点的值都大于其左子树上所有节点的值,且小于其右子树上所有节点的值;
(2)二叉查找树的每一个节点的左、右子树也分别是一棵二叉查找树。
平衡二叉查找树的特点:任意一个节点的左、右子树的高度(从该节点到叶子节点的最长路径的边数)之差不超过1(<=1)。
二叉查找树是通过二分查找,时间复杂度是O(logn),其中n是节点数。