redis核心数据结构——跳表项目设计与实现(跳表结构介绍,节点类设计,随机层级函数)

本文主要是介绍redis核心数据结构——跳表项目设计与实现(跳表结构介绍,节点类设计,随机层级函数),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

跳表结构介绍。跳表是redis等知名软件的核心数据结构,其实现的前提是有序链表,思想的本质是在原有一串存储数据的链表中,间隔地抽出一半元素作为上一级链表,并将抽提出的元素和原先的位置相关联,这样重复下去直到最上层只有一个节点。构建时比较复杂,但在查找元素时可以达到log(n)的时间复杂度。这也就是跳表这一名称的由来了。

此外等会要写ACM模式,cin cout大家都知道是iostream里面重载运算符后的输入输出方式,但也要注意下没有写using namespace std时cin和cout前都要加上std::,来说明是在标准命名空间下使用的,写了之后就不用加了。

还有new的使用方式。用过很多次new了,一直没有做个总结,这里顺便提下,

int *p = new int[6];int (*p)[10] = new int[3][10];int (*p)[10][20] = new int[5][10][20];//注意使用时不要越界了

下面正式进入跳表节点类设计的部分。

首先看设计需求

你的任务是实现跳表中用于表示节点的 Node 类。

Node 类有以下属性:

  • 键(key):节点存储的节点存储的数据键,可以是整数或者其他类型
  • 值(value):与键关联的数据值
  • 节点的层级标识(node_level):标示节点在跳表中的层级位置
  • 前向指针(forwards):一个指针数组,forwards[i] 表示当前节点在第 i 层的下一个节点

Node 类有以下成员函数:

  • 构造函数:接受键、值和节点级别(level)作为参数,节点级别决定了 forwards 数组的大小。
  • 析构函数:销毁 Node 以及回收内存空间
  • get_key() :获取节点的键
  • get_value() 和 set_value() 获取和设置节点的值

输入共一行,三个整数,用空格隔开,分别为 K, V, L,分别表示节点的键、值和节点的层数,请使用 Node 构造方法,创建一个节点。

输出共一行,两个整数,分别为 Node 的 key 和 value,空格隔开,末尾换行,请通过调用 Node 的 get_key() 和 get_value() 方法进行输出。

输入示例:

1 2 3

输出示例:

1 2

代码如下:

#include <iostream>class Node {
private:int key;int val;int node_level;Node* forwards;public:Node(int inkey, int value, int level): key(inkey), val(value), node_level(level),forwards(nullptr) {}~Node(){};int getKey() {return key;}int get_value() {return val;}void set_value(int value) {val = value;}};int main() {int k, v, l;std::cin >> k >> v >> l;Node* newNode = new Node(k, v,l);std::cout << newNode->getKey() << ' ';std::cout << newNode->get_value() << std::endl;delete newNode;
}

设计完类之后,我们要进入下一阶段,将类节点插入到链表中。我们首先需要确定它的层级,这里简单看下就行了,在做项目的过程中,也许并不需要去关注所有的全局细节,否则项目可能根本就做不好了。采用的是一种随机决定层数的手段。依据数学上的大数定律,在随机的次数多了,发生的频率就会贴近事情本来的概率,这也就是跳表的核心原理之一了。

代码如下:

#include<stdlib.h>
#include <iostream>
const int _max_level = 500;int getrandomLevel() {srand((int)time(0));int k = 1;while (rand() % 2) {k++;}k = (k < _max_level) ? k : _max_level;return k;
}int main() {int k = getrandomLevel();std::cout << k;
}

其中srand(time(0))是利用time函数取0为参数时返回值的变化来随机初始化rand,让其产生一种随机数的效果。

这篇关于redis核心数据结构——跳表项目设计与实现(跳表结构介绍,节点类设计,随机层级函数)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/953274

相关文章

使用Redis快速实现共享Session登录的详细步骤

《使用Redis快速实现共享Session登录的详细步骤》在Web开发中,Session通常用于存储用户的会话信息,允许用户在多个页面之间保持登录状态,Redis是一个开源的高性能键值数据库,广泛用于... 目录前言实现原理:步骤:使用Redis实现共享Session登录1. 引入Redis依赖2. 配置R

SpringBoot实现RSA+AES自动接口解密的实战指南

《SpringBoot实现RSA+AES自动接口解密的实战指南》在当今数据泄露频发的网络环境中,接口安全已成为开发者不可忽视的核心议题,RSA+AES混合加密方案因其安全性高、性能优越而被广泛采用,本... 目录一、项目依赖与环境准备1.1 Maven依赖配置1.2 密钥生成与配置二、加密工具类实现2.1

在Java中实现线程之间的数据共享的几种方式总结

《在Java中实现线程之间的数据共享的几种方式总结》在Java中实现线程间数据共享是并发编程的核心需求,但需要谨慎处理同步问题以避免竞态条件,本文通过代码示例给大家介绍了几种主要实现方式及其最佳实践,... 目录1. 共享变量与同步机制2. 轻量级通信机制3. 线程安全容器4. 线程局部变量(ThreadL

Django中的函数视图和类视图以及路由的定义方式

《Django中的函数视图和类视图以及路由的定义方式》Django视图分函数视图和类视图,前者用函数处理请求,后者继承View类定义方法,路由使用path()、re_path()或url(),通过in... 目录函数视图类视图路由总路由函数视图的路由类视图定义路由总结Django允许接收的请求方法http

python使用Akshare与Streamlit实现股票估值分析教程(图文代码)

《python使用Akshare与Streamlit实现股票估值分析教程(图文代码)》入职测试中的一道题,要求:从Akshare下载某一个股票近十年的财务报表包括,资产负债表,利润表,现金流量表,保存... 目录一、前言二、核心知识点梳理1、Akshare数据获取2、Pandas数据处理3、Matplotl

shell脚本批量导出redis key-value方式

《shell脚本批量导出rediskey-value方式》为避免keys全量扫描导致Redis卡顿,可先通过dump.rdb备份文件在本地恢复,再使用scan命令渐进导出key-value,通过CN... 目录1 背景2 详细步骤2.1 本地docker启动Redis2.2 shell批量导出脚本3 附录总

批量导入txt数据到的redis过程

《批量导入txt数据到的redis过程》用户通过将Redis命令逐行写入txt文件,利用管道模式运行客户端,成功执行批量删除以Product*匹配的Key操作,提高了数据清理效率... 目录批量导入txt数据到Redisjs把redis命令按一条 一行写到txt中管道命令运行redis客户端成功了批量删除k

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

精选20个好玩又实用的的Python实战项目(有图文代码)

《精选20个好玩又实用的的Python实战项目(有图文代码)》文章介绍了20个实用Python项目,涵盖游戏开发、工具应用、图像处理、机器学习等,使用Tkinter、PIL、OpenCV、Kivy等库... 目录① 猜字游戏② 闹钟③ 骰子模拟器④ 二维码⑤ 语言检测⑥ 加密和解密⑦ URL缩短⑧ 音乐播放