下面是一个简单的自定义C++ Array类实现,支持可变长数组:
#include <iostream>
class Array {
private:
int* data;
int size;
public:
Array() {
data = nullptr;
size = 0;
}
void push_back(int value) {
int* new_data = new int[size + 1];
for (int i = 0; i < size; i++) {
new_data[i] = data[i];
}
new_data[size] = value;
delete[] data;
data = new_data;
size++;
}
int at(int index) {
if (index < 0 || index >= size) {
std::cerr << "Index out of bounds" << std::endl;
return -1;
}
return data[index];
}
int get_size() {
return size;
}
~Array() {
delete[] data;
}
};
int main() {
Array arr;
arr.push_back(1);
arr.push_back(2);
arr.push_back(3);
std::cout << "Array size: " << arr.get_size() << std::endl;
std::cout << "Element at index 1: " << arr.at(1) << std::endl;
return 0;
}
在这个Array类中,我们使用动态分配的数组来存储元素,并实现了push_back()方法用于向数组末尾添加元素,at()方法用于获取指定索引的元素,get_size()方法用于获取数组的大小。在析构函数中,我们释放了动态分配的数组内存。
在主函数中,我们创建了一个Array对象,向其中添加了三个元素,并输出了数组的大小和索引为1的元素值。通过这个自定义Array类,我们可以方便地操作可变长数组。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。