The problem arise when I am trying to write an insert function that is suppose to move all elements in the array up at the specified location given by the iterator and then insert a new value into the array at the position given by the iterator.
The code is getting errors in the insert function with the following error:
no match for 'operator[]' (operand types are 'std::basic_string [1000]' and 'std::basic_string')
I am new to using iterators, and I think that it is not possible to access array elements with pointers as indices. So I am not sure if there is another way to do this, or do I need to overload the [] operator to make it work some how?
template <class T>
class Vector {
public:
typedef T* iterator;
Vector () { }
T& operator[](unsigned int i) {
return items[i];
}
// T& operator[](iterator i) {
//return items[*i];
//}
iterator begin () {
return &items[0];
}
iterator end () {
return &items[used];
}
int size () { return used; }
iterator insert (iterator position, const T& item) {
for(Vector<T>::iterator i=&items[998]; i>=position; i--)
{
items[*(i+1)]=items[*i];
}
items[*position]= item;
return position;
}
private:
T items[1000];
int used=0;
};
T items[1000];is an C-Array not aVector<T>soVector<T>::iterator i=&items[998];is ill formed.insert():iis of typeT*.*ias well as*(i + 1)has typeT&(a reference to aT). So, theitems[*(i + 1)]does not make sense. (If I got it right*(i + 1) = *i;would instead.)Vectornotstd::vector. I believe, OP tries to rebuild it for educational purpose.*position = item;.