跳跃表

本文介绍了跳跃表作为解决链表高效查询的一种数据结构。跳跃表通过多层指针实现快速查找,避免了链表逐个节点遍历的低效。文章详细讲解了跳跃表的思路、插入、查询和修改删除操作,并对比了跳跃表与二分法、HashMap等数据结构的适用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

闲聊

看了redis zset后,突然想写一篇跳跃表的文章。

说一说跳跃表,其实跳跃表的思想有点像二分法的思想,为什么不直接用二分呢,因为跳跃表一般处理的是链表而不是数组。如果是数组的话,只要维持有序,查的时候直接二分就行。二跳跃表要面对的一般是链表,链表不像数组内存地址连续,可以直接访问到想要的地方,链表的访问通常来讲是从头部开始遍历,或者尾部开始遍历。如果每找一个值都要一个一个查的话效率实在是太低,在面对大量的数据时有些力不从心。而跳跃表可以解决这个问题,虽说hashmap也可以解决这个问题,但是hashmap排序的话效果不是很好,而且重构成本也要更高。linkedhashmap确实是可以解决排序问题,但是维护的成本又变高了。估么redis设计的时候也是考虑了这些因素。

正题

思路

大致就是设计个节点,这个节点有上下左右四个指针,用于指向其他的节点。

大致就长成这个样子,直线代表指针,因为每一条都是双向的就不表明箭头了。

生成的时候先生成最下面的那一行,之后每隔一位上升一个节点,当然也可以随机上升,随机要好一些,一般都用随机,我这里为方便举例就用的固定的上升。

插入

插入的时候从最后一个节点开始往前找,找到合适的位置插入(需求不同实现不同,跳跃表不一定

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值