是一种动态的数据结构,它能够支持快速的插入、查找、查询操做.写起来并不复杂,甚至能够替代红黑树.git
对于一个单链表来说,即便链表中的储存数据是有序的.若是咱们想要在其中查找某个数据,也只能从头至尾遍历链表.这样的效率会很低,时间复杂度也很高 O(n)
.github
如何提高链表的查询效率呢? 咱们对链表创建一级索引层.每两个节点提取一个节点到上一级.图中的 down 表示 down 指针,指向下一级结点。
这种链表加多级索引的结构,就是
跳表
跳表采用空间换时间的设计思路,经过构建多级索引来提升查询的效率,实现了基于链表的二分查找
.跳表是一种动态的数据结构,支持快速的插入.数据结构
原文连接:https://www.zhanggaoyuan.com/article/4spa
原文标题:[跳表实现原理]设计
本站使用「 署名-非商业性使用 4.0 国际 (CC BY-NC 4.0)」创做共享协议,转载或使用请署名并注明出处。
本篇文章由一文多发平台ArtiPub自动发布指针