Hey Guys,
I will strongly suggest you to practice this thing. I thought that I "knew" how to build a template but everything changes when you have to actually sit and do it, those little mistakes will come up and you will be able to fix them before a test comes up (at least that's what I say to myself to be more confident :) ).
The point here is: Have you done the workshop for this subject? (https://scs.senecac.on.ca/~oop344/pages/workshops/w8.html) I found it very useful and hopefully will help you out to clear some thoughts.
Here is the answer built for this scenario and most important: Reviewed by professor!
//Design and code a template named Array for classes that manage one-dimensional, contiguously stored lists of objects of type E.
//The objects are by default of type double.
template <class E = double>
class Array{
private:
//Upon instantiation, an Array object receives the number of type E objects in the array.
E* data;
unsigned int arraySize;
E dummy;
protected:
public:
/*
Since the template dynamically allocates space for the specified number of elements,
your design includes a copy constructor, assignment operator and a destructor.
*/
//Constructor:
Array(int);
//Destructor:
~Array();
//Copy constructor:
Array(const Array&);
//Assignment operator:
Array& operator = (const Array);
unsigned int size() const;//an inline query that returns the number of elements in the array.
E& operator[](int i);
/*- an inline subscript operator that returns a reference to element i,
where the first element is at index 0.
If the value of i is outside array bounds, your operator returns a reference to
a dummy element of type E. */
//CHALLENGE:
friend void sort(Array<E>& a); // sorts the elements in an Array object. Receives a references to an Array object and sorts the elements in ascending order
};
template<class E>
Array<E>::Array(int n) : arraySize(n)
{
data = new E[n];
}
template<class E>
Array<E>::~Array()
{
delete [] data;
}
//Copy constructor:
template<class E>
Array<E>:: Array(const Array& b) : data(0)
{
*this = b;
}
//Assignment operator:
template <class E>
Array<E>& Array<E>::operator = (const Array b)
{
arraySize = b.size();
if(data)
delete [] data;
data = new E[arraySize];
for(int i = 0; i < size; i++)
data[i] = b.data[i];
}
//an inline query that returns the number of elements in the array.
template <class E>
unsigned int Array<E>::size() const
{
return arraySize;
}
/*- an inline subscript operator that returns a reference to element i,
where the first element is at index 0.
If the value of i is outside array bounds, your operator returns a reference to
a dummy element of type E. */
template <class E>
E& Array<E>::operator[](int i)
{
if( i >=0 && i < arraySize)
{
return data[i];
}
else
return dummy;
}
//// sorts the elements in an Array object. Receives a references to an Array object and sorts the elements in ascending order
template <class E>
void sort(Array<E>& a)
{
for(int i = 0; i < a.size(); i++)
{
for(int j = 0; j < a.size() - 1; j++)
{
if(a[j] > a[j+1])
{
auto t = a[j];
a[j] = a[j+1];
a[j+1] = t;
}
}
}
}