3 семестр

This commit is contained in:
2022-05-14 15:22:55 +03:00
parent 64597ccc7e
commit b18d091370
35 changed files with 3547 additions and 0 deletions

208
Part1/Lab2/Set4.h Normal file
View File

@@ -0,0 +1,208 @@
#include <iostream>
#include <fstream>
#include <string>
#include <Windows.h>
#include <cstdio>
#include <time.h>
using namespace std;
class SetElem {
public:
char el;
SetElem* next;
SetElem(char e, SetElem* n = nullptr) : el(e), next(n) { }
~SetElem() { delete next; }
};
class Set {
private:
static int N, cnt; // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
int n; // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
char S; // <20><><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
SetElem* A;
public:
Set operator | (const Set&) const; // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
Set& operator |= (const Set&);
Set operator & (const Set&) const; // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
Set& operator &= (const Set&);
Set operator ~ () const; // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
void Show(); // <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD>
int power() { return n; } // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
Set(char);// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
Set(); // <20><><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
Set(const Set&); // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>
Set(Set&&); // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (C++11)
Set operator = (const Set&); // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
Set operator = (Set&&); //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (C++11)
~Set() {} // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
};
Set::Set() : n(0), S('A' + cnt++), A(nullptr) {};
Set::Set(char) : S('A' + cnt++), n(0), A(nullptr) {
SetElem* pA = A;
for (int i = 0; i < N; i++)
if (rand() % 2) {
if (A) {
pA->next = new SetElem(char(i + 'A'));
pA = pA->next;
}
else {
A = new SetElem(char(i + 'A'));
pA = A;
}
n++;
}
cout << '\n' << S << " = [";
for (SetElem* p = A; p; p = p->next)
cout << p->el;
cout << "]";
}
Set::Set(const Set& B) : S('A' + cnt++), n(B.n), A(nullptr) {
SetElem* pA = A, * pB = B.A;
while (pB) {
if (pA) {
pA->next = new SetElem(pB->el);
pA = pA->next;
}
else {
A = new SetElem(B.A->el);
pA = A;
}
pB = pB->next;
}
}
Set Set:: operator= (const Set& B) {
if (this != &B) {
n = B.n;
A = nullptr;
SetElem* pA = A, *pB = B.A;
while (pB) {
if (pA) {
pA->next = new SetElem(B.A->el);
pA = pA->next;
}
else {
A = new SetElem(B.A->el);
pA = A;
}
pB = pB->next;
}
S = 'A' + cnt++;
}
return *this;
}
Set& Set :: operator &= (const Set& B)
{
n = 0;
SetElem* last = nullptr, * pA = A;
for (SetElem* pB = B.A; pB; pB = pB->next) {
while (pA && pA->el < pB->el) pA = pA->next;
if (pA && pA->el == pB->el) {
if (last == nullptr) {
last = pA;
A = pA;
}
else {
last->next = pA;
last = pA;
}
}
}
if (pA) last->next = nullptr;
for (pA = A; pA; pA = pA->next) n++;
return *this;
}
Set Set :: operator & (const Set& B) const
{
Set C(*this);
return std::move(C &= B);
}
Set& Set :: operator |= (const Set& B)
{
n = 0;
SetElem* pA = A;
for (SetElem* pB = B.A; pB; pB = pB->next) {
if (pA) {
while (pA->next && pA->next->el - 'A' < pB->el - 'A') pA = pA->next;
if (!pA->next || pA->next->el - 'A' != pB->el - 'A') {
if (pA == A) {
if (pB->el - 'A' <= pA->el - 'A') {
pA = new SetElem(pB->el, A);
A = pA;
}
}
else {
pA->next = new SetElem(pB->el, pA->next);
pA = pA->next;
}
}
}
else {
pA = new SetElem(pB->el);
A = pA;
}
}
for (pA = A; pA; pA = pA->next) n++;
return *this;
}
Set Set :: operator | (const Set& B) const
{
Set C(*this);
return std::move(C |= B);
}
Set Set :: operator ~ () const
{
Set C;
C.n = N - n;
SetElem* pC = C.A, *pA = A;
for (char c = 'A'; c <= 'Z'; ++c) { // <20><><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
if (pA && pA->el > c) {
if (pC) {
pC->next = new SetElem(c);
pC = pC->next;
}
else {
C.A = new SetElem(c);
pC = C.A;
}
}
else {
if(pA) pA = pA->next;
else {
pC->next = new SetElem(c);
pC = pC->next;
}
}
}
return std::move(C);
}
Set::Set(Set&& B) : S('A' + cnt++), n(B.n), A(B.A)
{
B.A = 0;
} // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
Set Set:: operator = (Set&& B) // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
{
if (this != &B)
{
n = B.n; A = B.A; S = 'A' + cnt++; B.A = 0;
}
return *this;
}
void Set::Show() {
cout << '\n' << S << " = [";
for (SetElem* p = A; p; p = p->next)
cout << p->el;
cout << "]";
}