模板--数组类

#include <cassert>
#include <ctime>
#include <iostream>
using namespace std;

template<typename T>
class Array{
private:
	T*list;
	int size;
public:
	Array(int sz=50);
	Array(const Array<T>&a);
	~Array();
	//实现[]重载;
	T&operator[](int i);  
	const T & operator [] (int i) const;
	//=等号运算符重载 
	Array<T> & operator =(const Array<T>&rhs);

	//增加重载+,-实现两个数组对应元素的加减操作
	Array operator+(const Array<T>&arr1);
	Array operator-(const Array<T>&arr1);

	//重载输出符<<
	friend ostream& operator<<(ostream& out,Array&a)
	{
		for(int i=0;i<a.size;i++)
		{
			out<<a.list[i]<<ends;
		}
		return out;
	}
};
template<class T>
Array<T>::Array(int sz){
	assert(sz>=0);
	size=sz;
	list=new T[size]();	 // 每个元素初始化为0
}
template<class T>
Array<T>::~Array(){
	delete[]list;
}
template<class T>
Array<T>::Array(const Array<T>&a){
	size=a.size;
	list=new T[size];
	for (int i=0;i<size;i++)
	{
		list[i]=a.list[i];
	}
}
template<class T>
Array<T> & Array<T>::operator=(const Array<T>&rhs){

	if (&rhs!=this)
	{
		if (size != rhs.size)
		{
			delete []list;
			size=rhs.size;
			list=new T[size];
		}
		for (int i=0;i<size;i++)
		{
			list[i]=rhs.list[i];
		}	
	}
	return *this;
}
template<class T>
Array<T>  Array<T>::operator+(const Array<T>&arr1)
{
	Array to(size);
	if (arr1.size == size)
	{
		for (int i=0;i<arr1.size;i++)
		{
			to.list[i]=list[i]+arr1.list[i];
		}	
	}	
	return to;
}
template<class T>
Array<T>  Array<T>::operator-(const Array<T>&arr1)
{
	Array to(size);
	if (arr1.size == size)
	{
		for (int i=0;i<arr1.size;i++)
		{
			to.list[i]=list[i]-arr1.list[i];
		}	
	}	
	return to;
}
template<class T>
T&Array<T>::operator[](int n){
	assert(n>=0&&n<size);
	return list[n];
}
template<class T>
const T&Array<T>::operator[](int n)const{
	assert(n>=0&&n>size);
	return list[n];
}

int main()
{
	Array<int>a1(10),a2(10),a3(10),a4(10),a5(10),a6(7),a7(7);	
	int i;
	for (i=0;i<10;i++)
	{
		a1[i]=rand()%10;
		a3[i]=rand()%10;
	}
	for (i=0;i<7;i++)
	{
		a7[i]=rand()%10;
	}
	cout<<a1[3]<<" "<<a3[0]<<endl;
	cout<<"数组a1\n"<<a1<<endl;
	cout<<"数组a3\n"<<a3<<endl;
	cout<<"数组a7\n"<<a7<<endl;  


	a2=a1;
	cout<<"数组a2=a1\n"<<a2<<endl;

	a4=a1+a3;
	cout<<"数组a4=a1+a3\n"<<a4<<endl;


	a5=a3-a1;
	cout<<"数组a5=a3-a1\n"<<a5<<endl;

	a6=a1+a7; //不相等则不做处理
	cout<<"数组a6=a1+a7\n"<<a6<<endl;

	/***********测试double型*****************/
	Array<double>da1(3),da2(3),da3(3);
	double a[6]={12.3,56.2,12.6,9.77};
	for (i=0;i<3;i++)
	{
		da1[i]=a[i];
	}
	cout<<da1<<endl;
	da2=da1;
	cout<<da2<<endl;

	da3=da1+da2;
	cout<<da3<<endl;

	/***********测试字符型*****************/
	Array<char> arr3(5),arr4(5),arr5(5);
	for (i=0;i<5;i++)
	{
		arr3[i]='G'+i;
	}
	cout<<arr3<<endl;
	arr4=arr3;
	cout<<arr4<<endl;

	for (i=0;i<5;i++)
	{
		arr3[i]=48+i;
	}
	cout<<arr3<<endl;

	system("pause");
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值