BitMap(位图)
|
? 1K=1024byte
? 1M=1024K=1024*1024byte(约100万个字节)
? 1G=1024M=1024*1024K=1024*1024*1024byte(约10亿个字节)
#pragma once
#include<vector>
using namespace std;
class BitMap
{
public:
BitMap(size_t range) //给定位图所能表示的范围
{
_bitmap.resize(range/32+1); //设置大小
}
void Set(size_t num) //置1
{
size_t index = num / 32; //计算所在下标
size_t bit = num % 32; //得位所在位置
_bitmap[index] |= (1 << bit);
}
void ReSet(size_t num) //置零
{
size_t index = num / 32; //计算所在下标
size_t bit = num % 32; //得位所在位置
_bitmap[index] &= (~(1 << bit));
}
bool Test(size_t num)
{
size_t index = num / 32; //计算所在下标
size_t bit = num % 32; //得位所在位置
return (_bitmap[index]>>num)&1;
}
private:
vector<size_t> _bitmap;
};
扩展: ? ?假设现在有100亿个无符号整数,现在要你找出只出现1次的数。(无符号整数所能表示的范围就是42亿9千万左右 ) 解析: ? ? 这里一个数不止出现一次,所以我们用一个bit位是不能解决这个问题的。因为一个数出现的状态有三种即:出现0次,出现1次,出现多次。要表示三种状态我们至少需要两个bit位才可以。假设现在用:00表示没出现,01表示出现1次,11(或10)表示出现多次。这样算下来也只需要1G左右的内存。 (编辑:安卓应用网_ASP源码网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
