跳表
跳表是一种各方面性能都比较优秀的动态数据结构,可以支持快速的插入、删除、查找操作。
跳表的实质就是一种可以进行“二分查找”的有序链表,跳表在原有的有序链表上面增加了多级索引,通过索引来实现快速查找。
理解跳表
对于一个单链表来讲,即便链表中存储的数据是有序的,如果我们要想在其中查找某个数据,也只能从头到尾遍历链表。
这样查找效率就会很低,时间复杂度会很高,时间复杂度是 O(n)。
如果我们在原始链表上建立一级“索引”,假如每两个结点提取一个结点到上一级,我们把抽出来的那一级叫作索引或索引层。
图中down表示down指针,指向下一级节点 。
建立索引层之后,假如我们现在要查找值为16的节点,我们就可以现在索引层遍历,当遍历到索引层中值为 13 的结点时,我们发现下一个结点是 17,16肯定就在这两个节点之间,我们通过索引层节点的down指针,下降到原始链表继续遍历,此时就只需要遍历2个节点,就可以查找到值等于16的节点了。
原本要查找16的节点,需要遍历10个节点,而现在只需要遍历7个节点。
增加一层索引后,查找一个结点需要遍历的结点个数减少了,也就是说查找效率提高了。
如果我们再增加一