美文网首页
数据结构中的跳表

数据结构中的跳表

作者: 寧远 | 来源:发表于2021-02-21 10:35 被阅读0次

跳表的定义:

跳表(Skip List)是由 William Pugh 发明的一种查找数据结构,支持对数据的快速查找,插入和删除,它比链表的出现时间要晚三十年左右。

基本思想:

跳表是一种类似于链表的数据结构。更加准确地说,跳表是对有序链表的改进。跳表在有序链表上的基础上进行了分层设计。

跳表示例图.png

以此类推,可以增加多级索引

特点:

只能用于元素有序的情况下,跳表(Skip list)对标的是平衡树和二分查找,它的插入/删除/搜索 都是 O(log n)

优势:

原理简单、容易实现、方便扩展、效率更高,在一些普遍的项目中代替平衡树,例如:Redis/LevelDB 等

提升点:

任何东西都不是孤立的存在,跳表其实是一种思想的升华,一维变二维(升维思想),但的确空间复杂度的变成了 O(n),典型的以空间换时间

相关文章

  • 定时器实现 & 红黑树,跳表

    跳表:是为一个有序的链表建立多级索引的数据结构叫做跳表。redis中zset数据量大时底层数据结构使用跳表。 re...

  • 有关跳跃表的干货都在这里

    跳表的数据结构 跳表全称叫做跳跃表,简称跳表。跳表是一个随机化的数据结构,实质就是一种可以进行二分查找的有序链表。...

  • HBase内存管理之MemStore

    基于跳表实现的MemStore基础模型 实现MemStore模型的数据结构是SkipList(跳表),跳表可以实现...

  • 数据结构中的跳表

    跳表的定义: 跳表(Skip List)是由 William Pugh 发明的一种查找数据结构,支持对数据的快速查...

  • 死磕 java集合之ConcurrentSkipListMap源

    前情提要 点击链接查看“跳表”详细介绍。 拜托,面试别再问我跳表了! 简介 跳表是一个随机化的数据结构,实质就是一...

  • 算法 1.6 跳表:Redis 中如何实现有序集合?【leetc

    题目描述 不使用任何库函数,设计一个跳表跳表是在 O(log(n)) 时间内完成增加、删除、搜索操作的数据结构跳表...

  • 跳表skiplist

    增加了向前指针的链表叫作跳表。跳表全称叫做跳跃表,简称跳表。跳表是一个随机化的数据结构,实质就是一种可以进行二分查...

  • 【算法打卡60天】Day36跳表:为什么Redis一定要用跳表来

    Day36学习内容 :跳表:为什么Redis一定要用跳表来实现有序集合?跳表是一种动态数据结构,实现灵活,可以通过...

  • 初识跳表

    什么是跳表 跳表是随机化的一个应用,以O(logn)的期望时间支持查找和插入的数据结构。跳表是链表的优化,在有序链...

  • LevelDB 中的跳表实现

    何为跳表 跳跃表(skiplist),简称「跳表」。是一种在链表基础上进行优化的数据结构,最早由 William ...

网友评论

      本文标题:数据结构中的跳表

      本文链接:https://www.haomeiwen.com/subject/ftaffltx.html