From 9c11fababb9b6b194e646fbeb62d141aacf74c43 Mon Sep 17 00:00:00 2001 From: Syndamia Date: Sat, 25 May 2024 16:08:17 +0300 Subject: [w13] Added solutions --- week13/Exercise2/Container.hpp | 75 +++++++++++++++++++++++++++++++++++++++++ week13/Exercise2/Indexable.hpp | 25 ++++++++++++++ week13/Exercise2/Resizeable.hpp | 34 +++++++++++++++++++ week13/Exercise2/Vector.hpp | 35 +++++++++++++++++++ 4 files changed, 169 insertions(+) create mode 100644 week13/Exercise2/Container.hpp create mode 100644 week13/Exercise2/Indexable.hpp create mode 100644 week13/Exercise2/Resizeable.hpp create mode 100644 week13/Exercise2/Vector.hpp (limited to 'week13/Exercise2') diff --git a/week13/Exercise2/Container.hpp b/week13/Exercise2/Container.hpp new file mode 100644 index 0000000..ace942f --- /dev/null +++ b/week13/Exercise2/Container.hpp @@ -0,0 +1,75 @@ +#pragma once + +template +class Container { + void free(); + void copyFrom(const Container& other); + +protected: + T* arr; + unsigned size; + +public: + Container(); + ~Container(); + Container(const Container& other); + Container& operator=(const Container& other); + Container(Container&& other); + Container& operator=(Container&& other); +}; + +template +void Container::free() { + delete[] arr; +} + +template +void Container::copyFrom(const Container& other) { + this->size = other.size; + this->arr = new T[size]; + for (int i = 0; i < size; i++) { + this->arr[i] = other.arr[i]; + } +} + +template +Container::Container() { + this->arr = nullptr; + size = 0; +} + +template +Container::~Container() { + free(); +} + +template +Container::Container(const Container& other) { + copyFrom(other); +} + +template +Container& Container::operator=(const Container& other) { + if (this != &other) { + free(); + copyFrom(other); + } + return *this; +} + +template +Container::Container(Container&& other) { + this->arr = other.arr; + other.arr = nullptr; +} + +template +Container& Container::operator=(Container&& other) { + if (this != &other) { + free(); + + this->arr = other.arr; + other.arr = nullptr; + } + return *this; +} diff --git a/week13/Exercise2/Indexable.hpp b/week13/Exercise2/Indexable.hpp new file mode 100644 index 0000000..dd5fb6b --- /dev/null +++ b/week13/Exercise2/Indexable.hpp @@ -0,0 +1,25 @@ +#pragma once +#include "Container.hpp" + +template +class Indexable : virtual public Container { +public: + T& operator[](unsigned index); + const T& operator[](unsigned index) const; +}; + +template +T& Indexable::operator[](unsigned index) { + if (index > this->size) { + throw "Index out of range!"; + } + return this->arr[index]; +} + +template +const T& Indexable::operator[](unsigned index) const { + if (index > this->size) { + throw "Index out of range!"; + } + return this->arr[index]; +} diff --git a/week13/Exercise2/Resizeable.hpp b/week13/Exercise2/Resizeable.hpp new file mode 100644 index 0000000..9b4fe04 --- /dev/null +++ b/week13/Exercise2/Resizeable.hpp @@ -0,0 +1,34 @@ +#pragma once +#include "Container.hpp" + +template +class Resizeable : virtual public Container { + void resize(); + +public: + void InsertAt(const T& element, unsigned index); +}; + +template +void Resizeable::resize() { + this->size++; + T* biggerArr = new T[this->size]; + for (int i = 0; i < this->size - 1; i++) { + biggerArr[i] = this->arr[i]; + } + delete[] this->arr; + this->arr = biggerArr; +} + +template +void Resizeable::InsertAt(const T& element, unsigned index) { + if (index >= this->size) { + throw "Index out of range!"; + } + + resize(); + for (int i = this->size - 1; i > index; i++) { + this->arr[i] = this->arr[i-1]; + } + this->arr[index] = element; +} diff --git a/week13/Exercise2/Vector.hpp b/week13/Exercise2/Vector.hpp new file mode 100644 index 0000000..ba66049 --- /dev/null +++ b/week13/Exercise2/Vector.hpp @@ -0,0 +1,35 @@ +#pragma once +#include "Indexable.hpp" +#include "Resizeable.hpp" + +template +class Vector : public Indexable, public Resizeable { +public: + void pop_back(); + void pop_front(); + void push_back(const T& element); + void push_front(const T& element); +}; + +template +void Vector::pop_back() { + this->size--; +} + +template +void Vector::pop_front() { + for (int i = 0; i < this->size - 1; i++) { + this->arr[i] = this->arr[i+1]; + } + this->size--; +} + +template +void Vector::push_back(const T& element) { + this->InsertAt(this->size - 1, element); +} + +template +void Vector::push_front(const T& element) { + this->InsertAt(0, element); +} -- cgit v1.2.3