数据结构与算法 / 跳表

博客介绍了跳表的诞生原因、基本信息和原理。跳表诞生是为解决链表查询耗时过长问题,由链表和多级索引组成。其查询在多个链表间跳跃,类似走台阶,是空间换时间的思想,时间复杂度为O(logn)。

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

一、诞生原因

解决链表查询时耗时过长的问题。

二、基本信息

英文全称:Skip List 。

链表 + 多级索引(链表) = 跳表

三、原理说明

顾名思义,跳表的查询是在多个链表之间跳跃查询的,其路线类似于走台阶,如下图所示:

 举个栗子:

某一时刻,想查询代号为 8 的节点的数据,按照常规链表查询,需要从最左侧挨个查询至最右侧,遍历次数为 8 ,时间复杂度为 O(n) 。

若添加一级索引,遍历次数为 5;若再添加二级索引,遍历次数为 4,遍历路线犹如下台阶一跳一跳的,故该结构名为跳表。

 跳表实际上是典型的空间换时间的思想。

时间复杂度:跳表可以说是利用多级链表实现的二分查找,如图所示,故 时间复杂度为 O(logn)

 

参考:极客时间《数据结构与算法之美》王争

这门课真心推荐,内容很经典、栗子很形象,里面还包含了很多面试题目。真是居家旅行必备良药。

 

(SAW:Game Over!)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值