From 7b19cabee8b08478f31f6e4594ed28e1d04e153c Mon Sep 17 00:00:00 2001 From: Syndamia Date: Fri, 10 May 2024 10:10:21 +0300 Subject: [w11] Solved exercises --- week11/Exercise09/DirectConcat.hpp | 32 ++++++++++ week11/Exercise09/DirectConcat.hpp.gch | Bin 0 -> 2106544 bytes week11/Exercise09/MixedArray.hpp | 107 +++++++++++++++++++++++++++++++++ week11/Exercise09/MixedConcat.hpp | 34 +++++++++++ 4 files changed, 173 insertions(+) create mode 100644 week11/Exercise09/DirectConcat.hpp create mode 100644 week11/Exercise09/DirectConcat.hpp.gch create mode 100644 week11/Exercise09/MixedArray.hpp create mode 100644 week11/Exercise09/MixedConcat.hpp (limited to 'week11/Exercise09') diff --git a/week11/Exercise09/DirectConcat.hpp b/week11/Exercise09/DirectConcat.hpp new file mode 100644 index 0000000..53f420b --- /dev/null +++ b/week11/Exercise09/DirectConcat.hpp @@ -0,0 +1,32 @@ +#pragma once +#include "MixedArray.hpp" + +template +class DirectConcat : public MixedArray { +public: + virtual MixedArray* operator+=(const MixedArray* other) override; +}; + +template +MixedArray* DirectConcat::operator+=(const MixedArray* other) { + T* biggerFirst = new T[this->allocated + other->allocated]; + U* biggerSecond = new U[this->allocated + other->allocated]; + + for (int i = 0; i < this->size; i++) { + biggerFirst[i] = this->first[i]; + biggerSecond[i] = this->second[i]; + } + for (int i = 0; i < other->size; i++) { + biggerFirst[this->size + i] = other->first[i]; + biggerSecond[this->size + i] = other->second[i]; + } + + delete[] this->first; + this->first = biggerFirst; + delete[] this->second; + this->second = biggerSecond; + this->allocated += other->allocated; + this->size += other->size; + + return this; +} diff --git a/week11/Exercise09/DirectConcat.hpp.gch b/week11/Exercise09/DirectConcat.hpp.gch new file mode 100644 index 0000000..d7e6e3f Binary files /dev/null and b/week11/Exercise09/DirectConcat.hpp.gch differ diff --git a/week11/Exercise09/MixedArray.hpp b/week11/Exercise09/MixedArray.hpp new file mode 100644 index 0000000..096a227 --- /dev/null +++ b/week11/Exercise09/MixedArray.hpp @@ -0,0 +1,107 @@ +#pragma once + +template +class MixedArray { + void free(); + void copyFrom(const MixedArray& other); + +protected: + T* first; + U* second; + unsigned allocated; + unsigned size; + +public: + MixedArray(); + virtual ~MixedArray(); + MixedArray(const MixedArray& other); + MixedArray& operator=(const MixedArray& other); + MixedArray(MixedArray&& other); + MixedArray& operator=(MixedArray&& other); + + void At(int index, T*& valueFirst, U*& valueSecond); + + virtual MixedArray* operator+=(MixedArray* other) = 0; +}; + +template +void MixedArray::free() { + delete[] first; + delete[] second; +} + +template +void MixedArray::copyFrom(const MixedArray& other) { + this->size = other.size; + this->allocated = other.allocated; + first = new T[allocated]; + second = new U[allocated]; + for (int i = 0; i < size; i++) { + first[i] = other.first[i]; + second[i] = other.second[i]; + } +} + +template +MixedArray::MixedArray() { + first = second = nullptr; + size = allocated = 0; +} + +template +MixedArray::~MixedArray() { + free(); +} + +template +MixedArray::MixedArray(const MixedArray& other) { + copyFrom(other); +} + +template +MixedArray& MixedArray::operator=(const MixedArray& other) { + if (this != &other) { + free(); + copyFrom(other); + } + return *this; +} + +template +MixedArray::MixedArray(MixedArray&& other) { + this->first = other.first; + other.first = nullptr; + this->second = other.second; + other.second = nullptr; + this->allocated = other.allocated; + this->size = other.size; +} + +template +MixedArray& MixedArray::operator=(MixedArray&& other) { + if (this != &other) { + free(); + + this->first = other.first; + other.first = nullptr; + this->second = other.second; + other.second = nullptr; + this->allocated = other.allocated; + this->size = other.size; + } + return *this; +} + +template +void MixedArray::At(int index, T*& valueFirst, U*& valueSecond) { + if (index < 0) throw "Index out of bounds!"; + + if (index % 2 == 0) { + valueFirst = *first[index / 2]; + valueSecond = nullptr; + } + else { + valueFirst = nullptr; + valueSecond = *second[(index - 1) / 2]; + } +} diff --git a/week11/Exercise09/MixedConcat.hpp b/week11/Exercise09/MixedConcat.hpp new file mode 100644 index 0000000..2b43f80 --- /dev/null +++ b/week11/Exercise09/MixedConcat.hpp @@ -0,0 +1,34 @@ +#pragma once +#include "MixedArray.hpp" + +template +class MixedConcat : public MixedArray { +public: + virtual MixedArray* operator+=(const MixedArray* other) override; +}; + +template +MixedArray* MixedConcat::operator+=(const MixedArray* other) { + T* biggerFirst = new T[this->allocated + other->allocated]; + U* biggerSecond = new U[this->allocated + other->allocated]; + + for (int i = 0; i < this->size + other->size; i++) { + if (i % 2 == 0) { + biggerFirst[i] = this->first[i / 2]; + biggerSecond[i] = this->second[i / 2]; + } + else { + biggerFirst[i] = other->first[(i - 1) / 2]; + biggerSecond[i] = other->second[(i - 1) / 2]; + } + } + + delete[] this->first; + this->first = biggerFirst; + delete[] this->second; + this->second = biggerSecond; + this->allocated += other->allocated; + this->size += other->size; + + return this; +} -- cgit v1.2.3