跳跃表-ConcurrentSkipListMap

序言

 

跳表(Skip List)是一种随机化的数据结构,插入、删除、查找的复杂度均为O(logN)

简单说来跳表也是链表的一种,只不过它在链表的基础上增加了跳跃功能,正是这个跳跃的功能,使得在查找元素时,跳表能够提供O(logN)的时间复杂度

 

二分查找要求元素可以随机访问,所以决定了需要把元素存储在连续内存。这样查找确实很快,但是插入和删除元素的时候,为了保证元素的有序性,就需要大量的移动元素了。

如果需要的是一个能够进行二分查找,又能快速添加和删除元素的数据结构,首先就是二叉查找树,二叉查找树在最坏情况下可能变成一个链表。

于是,就出现了平衡二叉树,根据平衡算法的不同有AVL树,B-Tree,B+Tree,红黑树等,但是AVL树实现起来比较复杂,平衡操作较难理解,这时候就可以用SkipList跳跃表结构。

 

实现一个 SkipList

 

跳跃表的应用

和字典、链表或者字符串这几种在 Redis 中大量使用的数据结构不同, 跳跃表在 Redis 的唯一作用, 就是实现有序集数据类型。

跳跃表将指向有序集的 score 值和 member 域的指针作为元素, 并以 score 值为索引, 对有序集元素进行排序。

 

 

资料

跳表(SkipList) 和 ConcurrentSkipListMap

https://www.sohu.com/a/293236470_298038

https://cloud.tencent.com/developer/article/1422115

posted @ 2020-09-12 19:40  ~沐风  阅读(186)  评论(0编辑  收藏  举报