This repository has been archived on 2022-06-05. You can view files and clone it, but cannot push or open issues or pull requests.
Files
AiSD/Part1/Lab2/Set2.h
2022-05-14 15:22:55 +03:00

122 lines
2.7 KiB
C++

#include <iostream>
#include <fstream>
#include <string>
#include <Windows.h>
#include <cstdio>
#include <time.h>
using namespace std;
class Set {
private:
static int N, cnt; // ìîùíîñòü óíèâåðñóìà è ñ÷åò÷èê ìíîæåñòâ
int n; // ìîùíîñòü ìíîæåñòâà
char S; // òåã è ïàìÿòü äëÿ ìíîæåñòâà
bool* 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 bool[N] {0}) {};
Set::Set(char) : S('A' + cnt++), n(0), A(new bool[N] {0}) {
for (int i = 0; i < N; i++)
if (rand() % 2) {
A[i] = true;
n++;
}
cout << '\n' << S << " = [";
for (int i = 0; i < N; i++)
if (A[i]) cout << char(i + 'A');
cout << "]";
}
Set::Set(const Set& B) : S('A' + cnt++), n(B.n), A(new bool[N] {0}) {
bool* dst(A), * src(B.A); // Èíèöèàëèçàöèÿ àäðåñîâ/ñ÷åò÷èêîâ
for (int i = 0; i < N; i++) *dst++ = *src++;
}
Set Set:: operator= (const Set& B) {
if (this != &B) {
bool* dst(A), * src(B.A); n = B.n;
for (int i = 0; i < N; i++) *dst++ = *src++;
S = 'A' + cnt++;
}
return *this;
}
Set& Set :: operator &= (const Set& B)
{
Set C(*this);
n = 0;
for (int i = 0; i < N; ++i) {
if (C.A[i] && B.A[i]) { A[i] = true; n++; }
else A[i] = false;
}
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 < N; ++i)
if (B.A[i]) {
A[i] = true;
n++;
}
return *this;
}
Set Set :: operator | (const Set& B) const
{
Set C(*this);
return std::move(C |= B);
}
Set Set :: operator ~ () const
{
Set C;
for (int i = 0; i < N; ++i) { // Öèêë ïî óíèâåðñóìó
C.A[i] = !A[i];
}
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 << " = [";
for (int i = 0; i < N; i++) if(A[i]) cout << char(i + 'A');
cout << "]";
}