内容简介:在一个结构中,用一个比特位来描述一个数据的状态,这种结构就称为位图。位图实际上是哈希表的一种变形
位图
github地址 https://github.com/xiaomeng79/go-algorithm
概念
在一个结构中,用一个比特位来描述一个数据的状态,这种结构就称为位图。位图实际上是哈希表的一种变形
位图可以干什么
- 大数据滤重
- 数据排序
为什么使用
- 节省内存
- 可以位操作,更快
代码
package bitmap
import "fmt"
//位图
type BitMap struct {
bits []byte
max int
}
//初始化一个BitMap
//一个byte有8位,可代表8个数字,取余后加1为存放最大数所需的容量
func NewBitMap(max int) *BitMap {
bits := make([]byte, (max>>3)+1)
return &BitMap{bits: bits, max: max}
}
//添加一个数字到位图
//计算添加数字在数组中的索引index,一个索引可以存放8个数字
//计算存放到索引下的第几个位置,一共0-7个位置
//原索引下的内容与1左移到指定位置后做或运算
func (b *BitMap) Add(num uint) {
index := num >> 3
pos := num & 0x07
b.bits[index] |= 1 << pos
}
//判断一个数字是否在位图
//找到数字所在的位置,然后做与运算
func (b *BitMap) IsExist(num uint) bool {
index := num >> 3
pos := num & 0x07
return b.bits[index]&(1<<pos) != 0
}
//删除一个数字在位图
//找到数字所在的位置取反,然后与索引下的数字做与运算
func (b *BitMap) Remove(num uint) {
index := num >> 3
pos := num & 0x07
b.bits[index] = b.bits[index] & ^(1 << pos)
}
//位图的最大数字
func (b *BitMap) Max() int {
return b.max
}
func (b *BitMap) String() string {
return fmt.Sprint(b.bits)
}
以上所述就是小编给大家介绍的《go 位图(bitmap)的实现》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- Lucene 位图实现 RoaringDocIdSet
- Redis应用-位图
- Redis应用-位图
- android如何保存位图 – buggy代码
- Redis 精确去重计数 —— 咆哮位图
- c# – 如何从URI下载图像并从中创建位图对象?
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
像程序员一样思考
V. Anton Spraul / 徐波 / 人民邮电出版社 / 2013-6 / 49.00元
编程的真正挑战不是学习一种语言的语法,而是学习创造性地解决问题,从而构建美妙的应用。《像程序员一样思考》分析了程序员解决问题的方法,并且教授你其他图书所忽略的一种能力,即如何像程序员一样思考。全书分为8章。第1章通对几个经典的算法问题切入,概括了问题解决的基本技巧和步骤。第2章通过实际编写C++代码来解决几个简单的问题,从而让读者进一步体会到问题解决的思路和应用。第3到7章是书中的主体部分,分别探......一起来看看 《像程序员一样思考》 这本书的介绍吧!