跳表实现原理

跳表实现原理

是一种动态的数据结构,它能够支持快速的插入、查找、查询操做.写起来并不复杂,甚至能够替代红黑树.git

对于一个单链表来说,即便链表中的储存数据是有序的.若是咱们想要在其中查找某个数据,也只能从头至尾遍历链表.这样的效率会很低,时间复杂度也很高 O(n).github

image.png

如何提高链表的查询效率呢? 咱们对链表创建一级索引层.每两个节点提取一个节点到上一级.图中的 down 表示 down 指针,指向下一级结点。

image.png
image.png

image.png

这种链表加多级索引的结构,就是 跳表

image.png

小结:

跳表采用空间换时间的设计思路,经过构建多级索引来提升查询的效率,实现了基于链表的二分查找.跳表是一种动态的数据结构,支持快速的插入.数据结构

原文连接:https://www.zhanggaoyuan.com/article/4spa

原文标题:[跳表实现原理]设计

本站使用「 署名-非商业性使用 4.0 国际 (CC BY-NC 4.0)」创做共享协议,转载或使用请署名并注明出处。
本篇文章由一文多发平台ArtiPub自动发布指针

相关文章
相关标签/搜索