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