当前位置: 首页 > news >正文

redis之Bitmap

位图数据结构其实并不是一个全新的玩意,我们可以简单的认为就是个数组,只是里面的内容只能为0或1而已(二进制位数组)。

GETBIT用于返回位数组在偏移量上的二进制位的值。值得我们注意的是,GETBIT的时间复杂度是O(1)

GETBIT命令的执行过程如下:

  1. 计算 (即>>3),byte 值表示指定的  位于位数组的哪个字节(计算在第几行);

  2. 指定  中的了,接下来就要计算在8个字节中的第几位呢?使用 计算可得;

  3. 根据  和  在位数组中定位到目标值返回即可。

 

 

BITCOUNT命令用于统计给定位数组中值为1的二进制位的数量。功能似乎不复杂,但实际上要高效地实现这个命令并不容易,需要用到一些精巧的算法。

1. 暴力遍历

2.查表法

 3.二进制位统计算法:variable-precision SWAR

目前已知效率最好的通用算法为variable-precision SWAR算法,该算法通过一系列位移和位运算操作,可以在常数时间(这就很牛逼了🐂😍)内计算多个字节的汉明重量,并且不需要使用任何额外的内存。

http://www.lryc.cn/news/100545.html

相关文章:

  • 建设数据中台到底有啥用?
  • [运维|系统] Centos设置本地编码
  • 深入探索Python中的os.listdir函数
  • ROS1ROS2之CmakeList.txt和package.xml用法详解
  • C#设计模式之---适配器模式
  • 串口设备驱动
  • Nginx实现反向代理和负载均衡
  • 小米手机MIUI优化的影响
  • 【图论】kruskal算法
  • Django框架:使用channels实现websocket,配置和项目实际使用
  • 基于RK3588+FPGA+AI算法定制的智慧交通与智能安防解决方案
  • AI面试官:LINQ和Lambda表达式(一)
  • FPGA学习——FPGA利用状态机实现电子锁模拟
  • Bert经典变体学习
  • uniapp checkbox radio 样式修改
  • 电脑重启后VScode快捷方式失效,找不到Code.exe
  • C语言实现扫雷游戏
  • 蓝图节点编辑器
  • MySql 知识大汇总
  • 深入浅出Pytorch函数——torch.sum
  • Git克隆文件不显示绿色勾、红色感叹号等图标
  • SOC FPGA之HPS模型设计(一)
  • 解决openstack重启swift服务后报错
  • [Linux]进程控制详解!!(创建、终止、等待、替换)
  • 全面适配 | 走近openGauss数据库+鲲鹏欧拉操作系统
  • 2023Robocom CAIP省赛 第四题 相对论大师
  • 【TypeScript】TS入门级基础学习(一)
  • jenkins执行jmeter时,报Begin size 1 is not equal to fixed size 5
  • 在 “小小容器” WasmEdge 里运行小小羊驼 llama 2
  • 【C#】async和await 续