#include <cstdlib>
#include <iostream>
#include "xcept.h"
using namespace std;
template<class T>
class Array1D
{
friend ostream& operator<<(ostream&, const Array1D<T>&);
public:
Array1D(int size = 0);
Array1D(const Array1D<T>& v);
~Array1D() {delete[] element;}
T& operator [](int i) const;
int Size(){return size;}
Array1D<T>& operator=(const Array1D<T>& v);
Array1D<T> operator+()const;
Array1D<T> operator+(const Array1D<T>& v)const;
Array1D<T> operator-()const;
Array1D<T> operator-(const Array1D<T>& v)const;
Array1D<T> operator*(const Array1D<T>& v)const;
Array1D<T> operator+=(const T& x);
Array1D<T>& ReSize (int sz);
private :
int size;
T*element;
};
template<class T>
Array1D<T>::Array1D(int sz)
{
if (sz < 0)throw BadInitializers();
size =sz;
element = new T[sz];
}
template<class T>
Array1D<T>::Array1D(const Array1D<T>& v)
{
size = v.size;
element = new T[size];
for (int i = 0; i<size; i++)
element [i]= v.element[i];
}
template<class T>
T& Array1D<T>::operator[](int i) const
{
if (i<0 || i >=size)throw OutOfBounds();
return element[i];
}
template<class T>
Array1D<T>&Array1D<T>::operator=(const Array1D<T>& v)
{
if (this != &v){
size= v.size;
delete[] element;
element = new T[size];
for (int i=0 ;i<size; i++)
element[i]= v.element[i];
}
return*this;
}
template<class T>
Array1D<T>Array1D<T>::operator+(const Array1D<T>& v)const
{
if (size != v.size) throw SizeMismatch();
Array1D<T> w(size);
for (int i =0; i<size;i++)
w.element[i]=element[i]+ v.element[i];
return w;
}
template<class T>
Array1D<T>Array1D<T>::operator-(const Array1D<T>& v)const
{
if (size != v.size) throw SizeMismatch();
Array1D<T> w(size);
for (int i =0; i<size;i++)
w.element[i]=element[i]-v.element[i];
return w;
}
template<class T>
Array1D<T>Array1D<T>::operator-()const
{
Array1D<T> w(size);
for (int i =0; i<size;i++)
w.element[i]=-element[i];
return w;
}
template<class T>
Array1D<T>Array1D<T>::operator*(const Array1D<T>& v)const
{
if (size != v.size) throw SizeMismatch();
Array1D<T> w(size);
for (int i =0; i<size;i++)
w.element[i]=element[i]* v.element[i];
return w;
}
template<class T>
Array1D<T>Array1D<T>::operator+=(const T& x)
{
for (int i =0; i<size; i++)
element[i] + = x;
return* this;
}
template<class T>
ostream& operator<<(ostream& out, const Array1D<T>& x)
{
for (int i =0; i< x.size; i++)
out<<x.element[i]<<" ";
return out;
}
template<class T>
Array1D<T>Array1D<T>::ReSize (int sz)
{
if (sz<0) throw BadInitializers();
delete [] element;
size = sz;
element = new T[size];
return* this;
}
#include < iostream.h>
#include "array1d.h"
void main(void)
{
try {
Array1D<int>x(10),y,z;
for(int i=0;i<10;i++)
x[i]=i;
cout<<"x[3]="<<x[3]<<endl;
cout<<"x is"<<x<<endl;
y=x;
cout<<"y is"<<y<<endl;
x+=2;
cout<<"x incremented by 2 is"<<x<<endl;
z=(y+x)*y;
cout<<"(y+x)*y is"<<z<<endl;
cout<<"-(y+x)*y is"<<-z<<endl;
}
catch(...){
cerr<<"An exception has occured"<<endl;}
}
Best view Wahyudi with Firefox 3+ & minimum monitor resolusion 1280×1024px
Belajar © Otak atik Blog ^^ Jadi maap kalo ada kekurangan