AddclasscontainingacircularbuffertoVector
创始人
2024-07-26 09:31:13
0

向Vector添加包含循环缓冲区的类的方法。

以下是一个示例代码,其中CircularBuffer类包含一个循环缓冲区,Vector类将它作为一个成员变量:

#include 

template 
class CircularBuffer {
    int capacity_;
    int front_;
    int rear_;
    std::vector buffer_;

public:
    CircularBuffer(int capacity)
            : capacity_(capacity), front_(0), rear_(0), buffer_(capacity_) {}

    void push_back(T val) {
        buffer_[rear_] = val;
        rear_ = (rear_+1) % capacity_;
        if (rear_ == front_) {
            front_ = (front_+1) % capacity_;
        }
    }

    T& operator[](int i) {
        return buffer_[(front_+i) % capacity_];
    }

    const T& operator[](int i) const {
        return buffer_[(front_+i) % capacity_];
    }
};

template 
class Vector {
    std::vector> data_;

public:
    void push_back(const T& val) {
        if (data_.empty() || data_.back().size() == data_.back().capacity()) {
            data_.push_back(CircularBuffer(10));
        }
        data_.back().push_back(val);
    }

    T& operator[](int i) {
        int j = 0;
        while (i >= data_[j].size()) {
            i -= data_[j].size();
            ++j;
        }
        return data_[j][i];
    }

    const T& operator[](int i) const {
        int j = 0;
        while (i >= data_[j].size()) {
            i -= data_[j].size();
            ++j;
        }
        return data_[j][i];
    }

    int size() const {
        int sz = 0;
        for (int i = 0; i < data_.size(); ++i) {
            sz += data_[i].size();
        }
        return sz;
    }
};

使用方法如下:

Vector v;
v.push_back(1);
v.push_back(2);
v.push_back(3);

for (int i = 0; i < v.size(); ++i) {
    std::cout << v[i] << " ";
}
// Output: 1 2 3

相关内容

热门资讯

Android Studio ... 要解决Android Studio 4无法检测到Java代码,无法打开SDK管理器和设置的问题,可以...
安装tensorflow mo... 要安装tensorflow models object-detection软件包和pandas的每个...
安装了Laravelbackp... 检查是否创建了以下自定义文件并进行正确的配置config/backpack/base.phpconf...
安装了centos后会占用多少... 安装了CentOS后会占用多少内存取决于多个因素,例如安装的软件包、系统配置和运行的服务等。通常情况...
按照Laravel方式通过Pr... 在Laravel中,我们可以通过定义关系和使用查询构建器来选择模型。首先,我们需要定义Profile...
按照分类ID显示Django子... 在Django中,可以使用filter函数根据分类ID来筛选子类别。以下是一个示例代码:首先,假设你...
Android Studio ... 要给出包含代码示例的解决方法,我们可以使用Markdown语法来展示代码。下面是一个示例解决方案,其...
Android Retrofi... 问题描述:在使用Android Retrofit进行GET调用时,获取的响应为空,即使服务器返回了正...
Alexa技能在返回响应后出现... 在开发Alexa技能时,如果在返回响应后出现问题,可以按照以下步骤进行排查和解决。检查代码中的错误处...
Airflow Dag文件夹 ... 要忽略Airflow中的笔记本检查点,可以在DAG文件夹中使用以下代码示例:from airflow...