C++ 因项目需求,需要将0~2的32次方这个区间的数字保存到内存当中(内存大小为4G),并且可以实现对任意一个数字的增删。(先叙述设计思路,再写岀代码)

问题: C++ 因项目需求,需要将0~2的32次方这个区间的数字保存到内存当中(内存大小为4G),并且可以实现对任意一个数字的增删。(先叙述设计思路,再写岀代码)

解答

为了在有限的内存(4GB)中存储和操作 0 到 2^32-1 之间的所有数字,我们需要考虑数据结构和存储策略。由于32位整数的范围很大(4,294,967,296 个可能的数字),我们需要一个高效的方式来存储和操作这些数字。在这种情况下,位图(bitmap)是一个合适的选择。

设计思路

  1. 位图(Bitmap)

    • 使用位图来表示数字的存在与否,每一个位(bit)对应一个数字。
    • 位图的大小需要 2^32 bits(约 512MB),因为每个数字占用1 bit。
  2. 内存分配

    • 4GB内存足够容纳整个位图。
    • 位图可以使用std::vector<uint8_t>来表示,每个uint8_t包含8个bit。
  3. 增删操作

    • 增加数字时,将对应位置的bit设置为1。
    • 删除数字时,将对应位置的bit设置为0。
  4. 辅助函数

    • 设置位函数:设置特定位置的bit为1。
    • 清除位函数:设置特定位置的bit为0。
    • 查询位函数:检查特定位置的bit是0还是1。

代码实现

cpp 复制代码
#include <iostream>
#include <vector>
#include <cstdint>

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;
}

说明

  1. Bitmap类

    • bitmap使用std::vector<uint8_t>存储位图数据。
    • add方法将对应的bit设置为1。
    • remove方法将对应的bit设置为0。
    • contains方法检查对应的bit是否为1。
  2. main函数

    • 创建一个Bitmap对象,大小为2^32位。
    • 测试添加和删除数字操作。

这种方法利用位图的高效性和位操作的快速性,在有限的内存中实现对大量数据的存储和操作。

相关推荐
dundunmm2 分钟前
机器学习之scikit-learn(简称 sklearn)
python·算法·机器学习·scikit-learn·sklearn·分类算法
古希腊掌管学习的神3 分钟前
[机器学习]sklearn入门指南(1)
人工智能·python·算法·机器学习·sklearn
波音彬要多做4 分钟前
41 stack类与queue类
开发语言·数据结构·c++·学习·算法
捕鲸叉5 分钟前
C++软件设计模式之外观(Facade)模式
c++·设计模式·外观模式
Swift社区12 分钟前
Excel 列名称转换问题 Swift 解答
开发语言·excel·swift
一道微光16 分钟前
Mac的M2芯片运行lightgbm报错,其他python包可用,x86_x64架构运行
开发语言·python·macos
矛取矛求20 分钟前
QT的前景与互联网岗位发展
开发语言·qt
Leventure_轩先生21 分钟前
[WASAPI]从Qt MultipleMedia来看WASAPI
开发语言·qt
向宇it35 分钟前
【从零开始入门unity游戏开发之——unity篇01】unity6基础入门开篇——游戏引擎是什么、主流的游戏引擎、为什么选择Unity
开发语言·unity·c#·游戏引擎
是娜个二叉树!1 小时前
图像处理基础 | 格式转换.rgb转.jpg 灰度图 python
开发语言·python