3 семестр
This commit is contained in:
118
Part1/Lab2/Set1.h
Normal file
118
Part1/Lab2/Set1.h
Normal file
@@ -0,0 +1,118 @@
|
||||
#include <iostream>
|
||||
#include <fstream>
|
||||
#include <string>
|
||||
#include <Windows.h>
|
||||
#include <cstdio>
|
||||
#include <time.h>
|
||||
|
||||
using namespace std;
|
||||
|
||||
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, * A; // <20><><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
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() { delete[] A; } // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
};
|
||||
|
||||
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); // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>/<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
while (*dst++ = *src++); // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> 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; // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
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) { // <20><><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
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;
|
||||
} // <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 = nullptr;
|
||||
}
|
||||
return *this;
|
||||
}
|
||||
|
||||
void Set::Show() { cout << '\n' << S << " = [" << A << "]"; }
|
||||
Reference in New Issue
Block a user