#include #include #include #include #include #include using namespace std; class Set { private: static int N, cnt; // мощность универсума и счетчик множеств int n; // мощность множества char S, * A; // тег и память для множества public: Set operator | (const Set&) const; // объединение Set& operator |= (const Set&); Set operator & (const Set&) const; // пересечение Set& operator &= (const Set&); Set operator ~ () const; // дополнение до универсума void Show(); // вывод множества на экран int power() { return n; } // получение мощности Set(char); // конструктор множества Set(); // еще конструктор — по умолчанию Set(const Set&); // конструктор копии Set(Set&&); // перемещающий конструктор (C++11) Set operator = (const Set&); // оператор присваивания Set operator = (Set&&); //присваивание с перемещением (C++11) ~Set() { delete[] A; } // деструктор }; Set::Set() : n(0), S('A' + cnt++), A(new char[N + 1]) { A[0] = 0; } Set::Set(char) : S('A' + cnt++), n(0), A(new char[N + 1]) { for (int i = 0; i < N; i++) if (rand() % 2) A[n++] = i + 'A'; A[n] = 0; cout << '\n' << S << " = [" << A << "]"; } Set::Set(const Set& B) : S('A' + cnt++), n(B.n), A(new char[N + 1]) { char* dst(A), * src(B.A); // Инициализация адресов/счетчиков while (*dst++ = *src++); // Копирование символов до обнаружения 0 } Set Set:: operator= (const Set& B) { if (this != &B) { char* dst(A), * src(B.A); n = B.n; while (*dst++ = *src++); S = 'A' + cnt++; } return *this; } Set& Set :: operator &= (const Set& B) { Set C(*this); n = 0; for (int i = 0; i < C.n; ++i) { for (int j = 0; j < B.n; ++j) if (C.A[i] == B.A[j]) A[n++] = C.A[i]; } A[n] = 0; // Ограничитель строки return *this; } Set Set :: operator & (const Set& B) const { Set C(*this); return std::move(C &= B); } Set& Set :: operator |= (const Set& B) { for (int i = 0; i < B.n; ++i) { bool f = true; for (int j = 0; j < n; ++j) if (B.A[i] == A[j]) f = false; if (f) A[n++] = B.A[i]; } A[n] = 0; return *this; } Set Set :: operator | (const Set& B) const { Set C(*this); return std::move(C |= B); } Set Set :: operator ~ () const { Set C; for (char c = 'A'; c <= 'Z'; ++c) { // Цикл по универсуму bool f = true; for (int j = 0; j < n; ++j) if (c == A[j]) { f = false; break; } if (f) C.A[C.n++] = c; } C.A[C.n] = 0; return std::move(C); } Set::Set(Set&& B) : S('A' + cnt++), n(B.n), A(B.A) { B.A = nullptr; } // Копирование с переносом Set Set:: operator = (Set&& B) // Присваивание с переносом { if (this != &B) { n = B.n; A = B.A; S = 'A' + cnt++; B.A = nullptr; } return *this; } void Set::Show() { cout << '\n' << S << " = [" << A << "]"; }