跳跃表

闲聊

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

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

正题

思路

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

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

生成的时候先生成最下面的那一行,之后每隔一位上升一个节点,当然也可以随机上升,随机要好一些,一般都用随机

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值