#include<iostream>
#include<stdlib.h>
using namespace std;
enum errortype {
invalidArraySize ,memoryAllocatetionError,indexOutOfRang
};
const char* errorMsg[] = { "invalid Array Size",",memory Allocatetion Error","indexOutOfRang" };
template<class T>
class Array {
private:
T* alist;
int size;
void Error( errortype error ) const{
cout << errorMsg[error] << endl;
}
public:
Array (int sz = 50);
Array(const Array<T>& X);
~Array(void);
Array<T>& operator=(const Array<T>& rhs);
T& operator[](int i);
int getsize(void) const;
void resize(int sz);
};
template<class T>
Array<T>::Array(int sz) {
if (sz <= 0) {
Error(invalidArraySize);
}
size = sz;
alist = new T[size];
if (alist == 0) {
Error(memoryAllocatetionError);
}
}
template<class T>
Array<T>::Array(const Array<T>& X) {
int n = X.size;
size = n;
alist = new T[n];
if (alist == 0) {
Error(memoryAllocatetionError);
}
T* srcptr = X.alist;
T* destptr = alist;
while (n--) {
*destptr++ = *srcptr++;
}
}
template<class T>
Array<T>::~Array() {
delete[]alist;
}
template<class T>
Array<T>& Array<T>:: operator=(const Array<T>& rhs) {
int n = rhs.size;
if (size!=n) {
delete[] alist;
alist = new T[n];
if (alist == 0) {
Error(memoryAllocatetionError);
}
}
size = n;
T* a = rhs.alist;
T* b = alist;
while (n--) {
*b++ = *a++;
}
return *this;
}
template<class T>
T& Array<T>::operator[](int i) {
if (i<0 || i>size - 1) {
Error(indexOutOfRang);
}
return alist[i];
}
template<class T>
int Array<T>::getsize(void)const {
return size;
}
template<class T>
void Array<T>::resize(int sz) {
size = sz;
delete alist;
alist = new T[size];
}
int main() {
int i;
int n1,n2;
cout << "请输入2个数组a1,a2的长度";
cin >> n1>>n2;
Array<int> a1(n1),a2(n2);
cout << "请输入a1数组的数";
for (i = 0; i < a1.getsize(); i++) {
cin >> a1[i];
}
cout << "a1数组为";
for (i = 0; i < a1.getsize(); i++) {
cout << a1[i] << " ";
}
cout << endl;
cout << "现在把数组a1复制给a2";
a2 = a1;
cout << "a2数组为";
for (i = 0; i < a1.getsize(); i++) {
cout << a2[i] << " ";
}
cout << endl;
cout << "现在你可以改变a1数组的长度,请输入想改变长度的值";
int m;
cin >> m;
a1.resize(m);
cout << "请输入" << m << "个数" << endl;
for (i = 0; i < a1.getsize(); i++) {
cin >> a1[i];
}
cout << "现在a1数组改变成了";
for (i = 0; i < a1.getsize(); i++) {
cout << a1[i]<<" ";
}
}
理解下面的动态数组类模板,它由一系列位置连续、任意数量相同类型的元素组成,其元素个数可在程序运行时改变,并完成该类中没有完成的成员函数(不允许改变已有代码),并设计主函数,实现对该模板类的功能测试
最新推荐文章于 2022-07-06 14:10:02 发布