问题: C++ 因项目需求,需要将0~2的32次方这个区间的数字保存到内存当中(内存大小为4G),并且可以实现对任意一个数字的增删。(先叙述设计思路,再写岀代码)
为了在有限的内存(4GB)中存储和操作 0 到 2^32-1 之间的所有数字,我们需要考虑数据结构和存储策略。由于32位整数的范围很大(4,294,967,296 个可能的数字),我们需要一个高效的方式来存储和操作这些数字。在这种情况下,位图(bitmap)是一个合适的选择。
位图(Bitmap):
内存分配:
std::vector来表示,每个uint8_t包含8个bit。增删操作:
辅助函数:
#include
#include
#include
class Bitmap {
public:
Bitmap(uint64_t size)
{
bitmap.resize((size + 7) / 8); // 每8个bit为1个byte
}
// 添加数字
void add(uint32_t num)
{
bitmap[num / 8] |= (1 << (num % 8));
}
// 删除数字
void remove(uint32_t num)
{
bitmap[num / 8] &= ~(1 << (num % 8));
}
// 检查数字是否存在
bool contains(uint32_t num) const
{
return bitmap[num / 8] & (1 << (num % 8));
}
private:
std::vector<uint8_t> bitmap;
};
int main()
{
Bitmap bitmap(1ULL << 32); // 创建一个包含 2^32 位的位图
// 测试添加和删除数字
uint32_t num = 123456789;
bitmap.add(num);
std::cout << "Contains " << num << "? " << (bitmap.contains(num) ? "Yes" : "No") << std::endl;
bitmap.remove(num);
std::cout << "Contains " << num << "? " << (bitmap.contains(num) ? "Yes" : "No") << std::endl;
return 0;
}
Bitmap类:
bitmap使用std::vector存储位图数据。add方法将对应的bit设置为1。remove方法将对应的bit设置为0。contains方法检查对应的bit是否为1。main函数:
Bitmap对象,大小为2^32位。这种方法利用位图的高效性和位操作的快速性,在有限的内存中实现对大量数据的存储和操作。