我在C++课程中有一个(本应该很简单的)作业。
以下是作业要求: 创建一个类模板,包含两个私有数据成员:T * array和int size。使用构造函数根据输入的大小分配数组。还有一个成员函数,允许用户根据大小填充数组。此外,还有一个成员函数对数组进行排序并显示已排序的元素。使用析构函数来删除数组。编写main()函数创建两个对象以调用成员函数。结果,第一个对象将保存其double类型的数组,而另一个对象将保存其int类型的数组。
以下是我想出的代码,但出现了“Allocation of incomplete type 'T'”错误:
以下是作业要求: 创建一个类模板,包含两个私有数据成员:T * array和int size。使用构造函数根据输入的大小分配数组。还有一个成员函数,允许用户根据大小填充数组。此外,还有一个成员函数对数组进行排序并显示已排序的元素。使用析构函数来删除数组。编写main()函数创建两个对象以调用成员函数。结果,第一个对象将保存其double类型的数组,而另一个对象将保存其int类型的数组。
以下是我想出的代码,但出现了“Allocation of incomplete type 'T'”错误:
#include <iostream>
#include <new>
#include <vector>
using namespace std;
template <class T>
class DynArray {
protected:
int size;
T ** DynamicArray = new T[size];
public:
DynArray(){
void CreateArray(){
cout << "Enter size of Array: ";
cin >> size;
for (int i = 0; i < size; ++i){
DynamicArray[i] = new T();
}
for (int i = 0; i<size; i++) {
cout << "Element " << i << ": ";
cin >> DynamicArray[i];}
}
//Sort Array
void Sort(T a[], int size)
{
int idx, pass;
for (pass=0; pass<size; ++pass){
for (idx=0; idx<size-1; ++idx){
if (a[idx] > a[idx+1])
swap(a[idx], a[idx+1]);}
}
for (int i=0; i<size; ++i) {
for (idx = 0; idx<size-1; ++idx) {
cout << a[idx] << " ";
}
}
}
void DeleteArray(){
for (int i = 0; i < size; ++i){
delete DynamicArray[i];
}
delete[] DynamicArray;
}
};
int main() {
DynArray<class T>();
return 0;
}
我不确定我的思路是否完全错误,还是只是缺少一些小细节。希望能得到帮助。
感谢@jblixr和@user3655463的帮助。在你们的提示和帮助下,我想我解决了这个问题。以下是我为其他人提供参考的解决方案。
#include <iostream>
#include <new>
#include <algorithm>
using namespace std;
//Template Class T
template <class T>
class DynArray {
protected:
int size;
T * DynamicArray;
public:
DynArray(){};
DynArray(size_t s): size(s) {
DynamicArray = new T[size];
for (int i = 0; i<size; i++) {
cout << "Element " << i << ": ";
cin >> DynamicArray[i];
}
}
//Sort Array
void Sort(){
sort(DynamicArray, DynamicArray+size);
for (int i=0; i<size; i++) {
cout << DynamicArray[i] << endl;
}
}
//Clear Heap
~DynArray() {
delete []DynamicArray;
}
};
int main() {
int sizeOfArry;
cout << "Enter size of Array: ";
cin >> sizeOfArry;
//Use as an int Array;
DynArray<int> intArray = DynArray<int>(sizeOfArry);
intArray.Sort();
}