数据结构——跳表(skip list)

跳表

跳表是一种各方面性能都比较优秀的动态数据结构,可以支持快速的插入、删除、查找操作。

跳表的实质就是一种可以进行“二分查找”的有序链表,跳表在原有的有序链表上面增加了多级索引,通过索引来实现快速查找。

 

理解跳表

对于一个单链表来讲,即便链表中存储的数据是有序的,如果我们要想在其中查找某个数据,也只能从头到尾遍历链表。

这样查找效率就会很低,时间复杂度会很高,时间复杂度是 O(n)。

 

如果我们在原始链表上建立一级“索引”,假如每两个结点提取一个结点到上一级,我们把抽出来的那一级叫作索引或索引层。

图中down表示down指针,指向下一级节点 。

建立索引层之后,假如我们现在要查找值为16的节点,我们就可以现在索引层遍历,当遍历到索引层中值为 13 的结点时,我们发现下一个结点是 17,16肯定就在这两个节点之间,我们通过索引层节点的down指针,下降到原始链表继续遍历,此时就只需要遍历2个节点,就可以查找到值等于16的节点了。

原本要查找16的节点,需要遍历10个节点,而现在只需要遍历7个节点。

增加一层索引后,查找一个结点需要遍历的结点个数减少了,也就是说查找效率提高了。

如果我们再增加一

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值