Homework 7 Solution

$30.00 $24.00

Goals In this assignment, you can finally code in C++ again. Topics covered are: Template Metaprogramming. Iterator. Const-correctness. A better understanding of the STL containers. Setup Download the following files: vector.hpp and Makefile. Overview Your task is to implement a vector in C++ using templates. Its behaviour should be similar to the std::vector. But of…

5/5 – (2 votes)

You’ll get a: zip file solution

 

Categorys:
Tags:

Description

5/5 – (2 votes)

Goals

In this assignment, you can finally code in C++ again. Topics covered are:

Template Metaprogramming.

Iterator.

Const-correctness.

A better understanding of the STL containers.

Setup

Download the following files: vector.hpp and Makefile.

Overview

Your task is to implement a vector in C++ using templates. Its behaviour should be similar to the std::vector. But of course the std::vector is more complicated – we implement a simplified version instead. vector.hpp defines all the classes needed and some of their data structures and methods. Other methods are left for you to declare. For templates, the program that is using them has to always include the implementation as well, because we cannot generate and link to a .o file because the code depends on the template parameter. To keep the code clean it is one convention to still only declare the classes and functions in a .hpp file while its implementation goes into a *-impl.hpp file which is included at the end of the .hpp file.

Implementation Details

Finish the implementation of the class and methods in vector-impl.hpp. And you should obey the following rules:

No standard libraries are allowed to use. Specifically, no #include statements are allowed to appear in vector-impl.hpp.

We assume type _Tp has default constructor and destructor, and it is both copy constructible and assignable.

The number of comments should be at least 25% of the non-blank lines. We will check by hand if those comments are valid and in English – failure to comply may lead to a score of 0 for this HW. You can use this Python script, which is the same as that on Autolab, to check your comments.

Iterator

Finish the implementation of __detail::__iterator<_Tp>. You have to implement the following methods:

Constructor: __iterator ()

Default constructor.

Constructor: __iterator ( const __iterator &

)

Copy constructor.

Constructor: __iterator ( _Tp *

)

Initialize the iterator with a pointer.

Destructor: ~__iterator ()

Destructor.

You should also overload the following operators:

=: copy assignment operator.

*: dereference operator.

->: arrow operator.

==, !=: comparison operator.

++,: self increment and decrement operator.

+,: arithmetic operator.

+=, -=: compound assignment operator.

These operators should behave similarly to std::vector<_Tp>::iterator.

Const Iterator

It is similar to the iterator except for the dereferenced value should be const type (they cannot be modified). All methods for iterator should also be implemented for const iterator. You should also implement one additional method:

Constructor: __const_iterator ( const __iterator & )

Convert an iterator into a const iterator. Please notice that the reverse conversion (const iterator -> iterator) is not required and you should consider why.

Vector

Finally, implement the vector. Implement the following methods:

Constructor: vector ()

Default constructor.

Constructor: vector (size_type , const _Tp & )

size

Create a vector with size copies of value. Constructor: vector (std::initializer_list<_Tp> l)

Create a vector consists of the elements in the initializer_list.

Destructor: ~vector ()

Destructor.

Operator: reference operator[] (size_type n)

Subscript access to the data contains in the vector.

Method: size_type size () const

Returns the size of the vector.

Method: iterator begin ()

Returns an iterator to the first element. If the vector is empty, the returned iterator will be equal to end().

Method: iterator end ()

Returns an iterator to the element following the last element.

Method: const_iterator cbegin () const

Returns a const iterator to the first element. If the vector is empty, the returned iterator will be equal to cend().

Method: const_iterator cend () const

Returns a const iterator to the element following the last element.

Method: iterator insert ( iterator

, const _Tp &

)

Method: iterator insert ( const_iterator

, const _Tp &

)

Insert given value into vector before specified iterator, return an iterator that points to

the inserted data.

Method: void push_back (const _Tp &value)

Add data to the end of the vector.

Method: iterator erase ( iterator

)

Method: iterator erase ( const_iterator

)

Remove the element at given position. Returns an iterator to the next element (or end()).

Method: void pop_back ()

Remove last element.

Method: inline void _grow ()

Grow vector to the size of capacity.

Please note that the copy and move constructors are removed in order to avoid memory issues like double free.

Hints

You can refer to the GNU C++ Library‘s implementation. In GNU/Linux, the header file

for std::vector is placed at /usr/include/c++/<GCC version>/.

Because the compiler will not generate any code if the templates are not used, so it won’t complain about errors exist in methods you do not use. It is strongly suggested that you test all your methods before submission. One easy approach is to specialize your templates and compile it.

The meaning of _M_size and _M_capacity is identical to HW2. _M_size should not be larger

than _M_capacity.

Make use of function _grow() properly. You may choose your own way to grow the vector.

Submission

Submit vector-impl.hpp to Autolab.

soerensch AT shanghaitech.edu.cn>

wangchd AT shanghaitech.edu.cn>

Last modified: 2020-04-19

Homework 7 Solution
$30.00 $24.00