数据结构 -- 跳表

news2024/11/28 0:30:17

文章目录

      • 概要
      • 跳表的结构
      • 跳表的查找过程
      • 插入操作
      • 删除操作
      • 补充

概要

跳表(Skip List)是一种基于链表的数据结构,通过增加多级索引来加速查找、插入和删除操作。它可以看作是链表与二分查找的结合体,能够在保持数据有序的同时,实现快速的查找,时间复杂度与平衡树(如红黑树)相同,但实现上更为简单。(跳表又称为:多层级的有序链表

跳表结构:
b站看视频截的图一张图

跳表的结构

跳表通过构建多层级的链表来提高查找效率。最底层的链表是一个完全有序的链表,包含所有的元素。随着层级升高,每一层链表都会跳过一些元素,从而使查找路径变短。通过这种分层的方式,可以在保持数据有序的同时,实现类似于平衡树的快速查找性能。

  • 最底层链表:包含所有元素,按升序排列。所有的搜索最终都会回到这一层,保证能够找到元素。
  • 上层索引:每一层的节点是下一层节点的一个子集,用于跳跃式查找。每层链表都按一定概率选取前一层的节点,形成多个层级。

跳表的典型结构如下图所示:

第3层 :   [3]------------------->[7]----------->[12]
第2层 :   [3]----------->[5]---->[7]----->[10]->[12]
第1层 :   [3]->[4]->[5]->[6]->[7]->[8]->[9]->[10]->[12]
  • 最底层 Level 1 包含所有元素。
  • 上层的每一层是下一层的子集,用于跳跃式查找,加快定位。(降低了查找时间复杂度,但是重复节点需要额外空间

跳表的查找过程

跳表的查找类似于二分查找的思想,通过从上到下、从左到右逐步缩小范围,找到目标元素。

查找步骤:

  1. 从最高层(第一个非空层级)的头节点开始,向右移动,直到当前节点的右边节点大于目标值或右边没有节点。
  2. 如果右边节点大于目标值或者没有右节点,下降到下一层,继续从当前节点向右查找。
  3. 重复步骤 1 和 2,直到降到最底层。
  4. 在最底层找到目标元素,返回结果;如果不存在则返回 null

例如,查找值 9 的过程:

  • 从 第3层 开始,3 -> 7 之后,右边的 129 大,往下到 Level 2。
  • 在 第2层,7 -> 10,右边的 109 大,继续往下到 Level 1。
  • 在 第1层,从 7 -> 8 -> 9,找到了目标元素 9

插入操作

插入操作同样从最上层开始,但每当插入一个新节点时,还需要决定是否将该节点插入到更高层级中(即是否创建该节点的索引)。跳表通过随机化策略来决定节点是否在更高层级出现。

插入步骤:

  1. 按照查找操作,从最高层开始找到插入位置,在最底层找到插入点。
  2. 插入元素到最底层的链表中。
  3. 通过随机选择决定是否将节点插入到更高层级,如果是,则在更高层中插入相应的节点索引。
  4. 重复步骤 3,直到随机选择决定不再向上插入或达到跳表的最高层。

例如,插入 11 的过程:

  • 在 Level 1 找到 1012 之间的位置,插入 11
  • 随机选择决定 11 也出现在 Level 2 中,于是在 Level 2 的 1012 之间插入 11
  • 再次随机决定 11 不会出现在更高层级,插入结束。

删除操作

删除操作与查找操作类似,从最高层开始查找需要删除的元素,找到元素后,在每一层级的链表中删除该元素的索引。

删除步骤:

  1. 从最高层开始,逐步向下查找目标元素。
  2. 一旦找到目标元素,在所有包含该元素的层级中删除该元素的节点。
  3. 当删除完所有层级中的节点后,跳表结构自动调整。

补充

Redis 的有序集合(Sorted Set)就是用跳表实现的,它能够高效支持插入、删除、查找、范围查询等操作。


红黑树:平衡二叉搜索树
B+树:多路平衡搜索树(和跳表类似,所有数据在最后一个层级有序)


面试题:Redis 的有序集合为什么不使用红黑树?
答:跳表范围查询高效

面试题:Redis 的有序集合为什么不使用B+树?
答:

  1. 复杂度和性能:B+ 树的时间复杂度是 O(log n),但是其底层结构需要维护多个层次的节点分裂、合并等复杂操作,特别是在插入和删除时,涉及平衡和重构,带来较高的性能成本。而 跳表(SkipList) 的时间复杂度同样是 O(log n),但其结构更简单,动态操作(如插入、删除、更新)的实现也更加直接,符合 Redis 追求简洁高效的设计理念。

  2. 基于内存的设计:Redis 是一个基于内存的数据库,不需要频繁访问磁盘,因此无需像 B+ 树那样专门为磁盘 I/O 优化。在内存环境下,跳表能够提供足够的性能,且其实现简单,内存占用也较为合理。


❤觉得有用的可以留个关注ya❤

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2206753.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

使用IMX6UL定时器EPTI实现延时

上一节,我们讲解了如何使用Imx6uL上面的定时器EPTI,这一节我们将使用EPTI进行实战,也就是使用定时器的效果来使用延时 在之前的实验中我们都使用到了按键,用到按键就要处理因为机械结构带来的按键抖动问题,也就是按键消…

ELK:Elasticsearch、Logstash、Kibana Spring Cloud Sleuth和Spring Cloud Zipkin

〇、虚拟机中docker安装elasticsearch 、Kibana、Logstash elasticsearch导入中文分词器 Logstash修改es数据库ip及创建索引名配置 一、elasticsearch数据库的结构 和mysql作比较,mysql中的数据库的二维表相当于es数据库的index索引结构;mysql数据库的二…

Java_EE ( IO 流技术)

什么是IO输入(Input)指的是:可以让程序从外部系统获得数据(核心含义是“读”,读取外部数据)。输出(Output)指的是:程序输出数据给外部系统从而可以操作外部系统(核心含义是“写”,将数据写出到外…

七言-重阳寄友

题 记 九九重阳节,岁岁嵌在仲秋季节里,人们的心情也便随着气温的下降而逐渐地沉静下来。 丰收的喜悦洋溢在山水和田野之间。金黄的稻穗低垂着头,仿佛在向大地母亲致以最深情的敬意。 果园里,沉甸甸的苹果、梨子挂满枝头&#…

职场上的人情世故你知多少

1.发微信找人帮忙,半天不回,那基本没戏了,不要再打扰了,懂得都懂。 2.能力越大,事情越多,要懂得张弛有度,不要把自己全抛出去,给自己留点余地,毕竟你不知道别人如何暗地…

关于电动车新国标要求的北斗定位功能资料

一、安装及接口 电动自行车应内置北斗定位模块,安装于电动自行车不易损坏的固定部件中。定位装置所采用的芯片或模组应支持UAR或SPI接口至少支持接收处理北斗 B1C和B2a信号 二、定位检测环境 应具备接收实际卫星信号并进行电动自行车整车运行状态下检测的实验室条件…

【Axure安装包与汉化包附带授权证书】

一、下载Axure安装包与汉化包附带授权证书 1.下载汉化包 【快传】: 点击链接即可保存 2.解压安装包 解压下载好的压缩包,能看到有lang也就是汉化包,AxureRP-Setup-RC.exe 也就是Axure9的安装程序,以及汉化说明和授权码。 二、安装Axure9…

机器人末端的负载辨识

关节处的摩擦力变小了,导致系统的参数辨识精度会变高,因为动力学方程中的摩擦力项占的比例会变小。 为什么要有一个负载的参数辨识,因为对于整个系统来说,除了负载哈,其他关节都是不变的,出厂时都设置好了&…

用YOLOv5跑口罩佩戴识别时的一些问题解决

文章目录 1. 问题12. 问题23. 问题3 1. 问题1 1. 报错:TypeError: No loop matching the specified signature and casting was found for ufunc greater. 2. 原因:版本不兼容。 3. 解决: 先查看当前的 numpy 版本:pip list卸载当…

【动手学深度学习】5.2 参数管理(个人向笔记+代码注释)

之前的课程中,我们只是通过深度学习框架完成训练的工作,而忽略了操作参数的具体细节。所以我们我们介绍的内容有: 访问参数,用于调试,诊断和可视化参数初始化在不同的模型组件间共享参数 下面是一个有单隐藏层的多层感…

基于Python flask的豆瓣电影可视化系统,豆瓣电影爬虫系统

博主介绍:✌Java徐师兄、7年大厂程序员经历。全网粉丝13w、csdn博客专家、掘金/华为云等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取源码联系🍅 👇🏻 精彩专栏推荐订阅👇🏻 不…

猿人学 — 第1届第17题(解题思路附源码)

猿人学 — 第1届第17题 根据题目“天杀的Http2.0”大概知道,请求的协议应该遵照的是Http2.0协议,并且目标网站专门对此进行了检测,在Network面板中右键表头,勾选Protocol 果不其然,一堆请求都是遵照Http2.0协议。而u…

2023年4月自考《数据库系统原理》04735试题

目录 一:选择题 二:填空题 三:设计题 四:简答题 五:综合题 一:选择题 1.在数据库系统中,专门用户建立和管理数据的软件是 (书中)P28页 A.DBS B.DB C.DBA D.DBMS 2.通常所说的数据库系统容不包括 (书中)P29页 A.应用程序 B.数据库管理员 C.用户 D.网络环境 …

Datawhale 组队学习 文生图 Prompt攻防 task01

文生图大模型面临着巨大的滥用风险,如生成虚假、违法违规、血腥恐怖或歧视仇恨的图片,评估此类模型和系统的安全防范能力至关重要。 赛题背景:从产业应用需求出发,体验为大模型注入生成式“风险疫苗”,透视大模型生图潜…

Java SE vs Java EE 与 JVM vs JDK vs JRE

Java SE(Java Platform,Standard Edition): Java 平台标准版,Java 编程语言的基础,它包含了支持 Java 应用程序开发和运行的核心类库以及虚拟机等核心组件。Java SE 可以用于构建桌面应用程序或简单的服务器应用程序。…

聚类分析 | IPOA优化FCM模糊C均值聚类优化算法

目录 效果一览基本介绍程序设计参考资料 效果一览 基本介绍 (多图聚类)IPOA优化FCM模糊C均值聚类优化算法,matlab代码,超多图 基于改进的鹈鹕优化算法(IPOA)优化FCM模糊C均值聚类优化,matlab代码,直接运行…

万字长文解读预测市场的历史发展与未来前景

撰文:Alex Nardi,Shoal Research 编译:Yangz,Techub News 文章要点: 预测市场的发展和影响:预测市场利用集体智慧预测未来事件的能力日益得到认可,对政治、金融、娱乐和流行文化等领域产生了重…

HiRT | 异步控制策略,告别VLA时延问题

论文:HiRT: Enhancing Robotic Control with Hierarchical Robot Transformers 前言:HiRT 通过异步处理的策略,将 VLM 作为低频慢思考过程,将轻量的动作策略模型作为高频快响应过程 ,以此解决 VLA 驱动带来的控制时延问…

Ubuntu22.04环境下源码安装OpenCV 4.8.1

因为项目需要用OpenCV对yolov8模型进行推理,通过DNN模块,之前本地的OpenCV版本是4.5.4(好像安装完ROS2 humble之后系统就自带了opencv),加载onnx模型一直报错,网上查询到需要4.7以上,干脆直接升…

vue3之依赖注入provide(提供)/inject(注入)

通常情况下,需要从父组件传值到子组件使用props足以,但是如果是深层嵌套的组件,如果某个深层的组件想要得到祖先组件的部分数据,使用props的话需要沿着各个嵌套的组件着层传递数据,而在传递过程中的组件压根就不需要使…