redis的跳表

csharp 复制代码
typedef struct zskiplistNode {
    // 分值
    double score;
    // 成员对象
    robj *obj;
    // 后退指针
    struct zskiplistNode *backward;
    // 层
    struct zskiplistLevel {
        // 前进指针
        struct zskiplistNode *forward;
        // 跨度
        unsigned int span;
    } level[];
} zskiplistNode;

跳表的节点查找算法可以描述如下:

从跳表的头节点开始。

在当前层级上,从最右侧开始,逐个比较节点的值,直到找到一个节点的值大于或等于目标值。

如果当前节点的值等于目标值,则返回该节点,查找结束。

如果当前节点的值大于目标值,则向下移动到下一层级。

重复步骤2和3,直到找到目标节点或者到达跳表的底层。

跳表的插入算法描述如下:

随机生成层数。

插入新节点时,需要在每一层都更新对应的指针,使得新节点能够正确地插入到每一层中。

相关推荐
l1t2 小时前
DeepSeek总结的 pg_regresql插件:真正可移植的 PostgreSQL 统计信息
数据库·postgresql
oradh2 小时前
Oracle 11.2.0.1版本升级至11.2.0.4_单机环境
数据库·oracle·oracle11g·oracle升级
l1t2 小时前
用docker安装测试crate数据库
数据库·docker·容器·cratedb
anzhxu2 小时前
QT数据库(三):QSqlQuery使用
数据库·qt·oracle
身如柳絮随风扬3 小时前
MySQL核心知识
数据库·mysql
德彪稳坐倒骑驴3 小时前
Oracle 11g安装
数据库·oracle
韩立学长3 小时前
Springboot校园跑腿业务系统0b7amk02(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
阿贵---3 小时前
使用XGBoost赢得Kaggle比赛
jvm·数据库·python
想七想八不如114083 小时前
数据库--样题复习
数据库·sql·oracle
551只玄猫3 小时前
【数据库原理 实验报告1】创建和管理数据库
数据库·sql·学习·mysql·课程设计·实验报告·数据库原理