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

View File

@@ -0,0 +1,255 @@
#include <iostream>
#include <fstream>
#include <string>
#include <Windows.h>
#include <cstdio>
#include <time.h>
#include <iomanip>
using namespace std;
const char universum[] = "ABCDEFGHIJKMNLOPQRSTUVWXYZ";
const char filename[] = "Test_result.txt";
const int length = 26;
const int durationCoeff = 1000000;
int customTestAmount = 0;
char stringA[length], stringB[length], stringC[length], stringD[length];
unsigned int vectorA, vectorB, vectorC, vectorD, vectorF;
void setupConsole()
{
setlocale(LC_ALL, "Russian");
SetConsoleOutputCP(1251);
SetConsoleCP(1251);
cout << fixed;
cout << setprecision(7);
}
void outputGreeting()
{
cout << "Программа рассчитывает значение множества F согласно следующим законам - " << endl;
cout << "F = D && (A || B) && !C, что равносильно F = D*(A + B) - C." << endl;
cout << "Универсум: " << universum << endl;
}
void input()
{
cout << endl;
cout << "- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -" << endl;
cout << "Введите множество A: ";
cin >> stringA;
cout << "Введите множество B: ";
cin >> stringB;
cout << "Введите множество C: ";
cin >> stringC;
cout << "Введите множество D: ";
cin >> stringD;
cout << endl;
}
bool isCorrectSymbol(char symbol)
{
return ((symbol >= universum[0] && symbol <= universum[length - 1]) || symbol == '\0') ? 1 : 0;
}
bool isStringCorrect(char* string)
{
for (int i = 0; i < length && string[i] != '\0'; i++)
if (!isCorrectSymbol(string[i]))
return 0;
return 1;
}
int memberToIndex(char member)
{
return member - universum[0];
}
char indexToMember(int number)
{
return number + universum[0];
}
unsigned int vectorFromString(const char string[])
{
int vector = 0;
for (int i = 0; string[i]; ++i)
vector |= (1 << memberToIndex(string[i]));
return vector;
};
void convertSets()
{
vectorA = vectorFromString(stringA);
vectorB = vectorFromString(stringB);
vectorC = vectorFromString(stringC);
vectorD = vectorFromString(stringD);
}
void calculateAnswer()
{
vectorF = vectorD & (vectorA | vectorB) & ~vectorC;
}
void outputSetToConsole(int vector)
{
for (int i = 0, k = 0; i < length; ++i)
if ((vector >> i) & 1)
cout << indexToMember(i);
}
void outputSetToFile(int vector, ofstream& output)
{
for (int i = 0, k = 0; i < length; ++i)
if ((vector >> i) & 1)
output << indexToMember(i);
}
bool isSetEmpty(int vector)
{
if (vector == 0)
return 1;
else return 0;
}
void outputAnswer()
{
cout << "Ответ: F = ";
if (isSetEmpty(vectorF))
cout << "пустое множество";
else
outputSetToConsole(vectorF);
cout << endl;
}
double calulateDuration()
{
double firstPoint, lastPoint, duration = 0;
for (int i = 0; i < durationCoeff; i++)
{
firstPoint = clock();
calculateAnswer();
lastPoint = clock();
duration += lastPoint - firstPoint;
}
return duration / durationCoeff;
}
void outputDuration()
{
cout << endl;
cout << "- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -" << endl;
cout << "Временная сложность алгоритма - O(1), постоянное время" << endl;
cout << "На выполнение алгоритма уходит " << calulateDuration() << " секунд." << endl;
cout << endl;
}
float factorial(int number)
{
float factorial = 1;
for (int i = 1; i <= number; i++)
factorial *= i;
return factorial;
}
int randomInt(int max)
{
return rand() % (max + 1);
}
unsigned int randomVector(long long max)
{
return (rand() * 2 + randomInt(1)) * (rand() * 2 + randomInt(3));
}
void fillVectors()
{
unsigned int maxVector = pow(2, length) - 1;
for (int i = 0; i < length; i++)
{
vectorA = randomVector(maxVector);
vectorB = randomVector(maxVector);
vectorC = randomVector(maxVector);
vectorD = randomVector(maxVector);
}
}
void badInputLoop()
{
while (cin.fail() || customTestAmount < 0)
{
cout << "Неправильный ввод, повторите еще раз:" << endl;
cin.clear();
cin.ignore(32767, '\n');
cin >> customTestAmount;
}
}
void testInfo()
{
cout << setprecision(0);
cout << "- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -" << endl;
cout << "Из 26 символов может быть составлено " << factorial(length) << " перестановок" << endl;
cout << "Сколько программа должна проделать тестов со случайными комбинациями?" << endl;
cin >> customTestAmount;
badInputLoop();
if (customTestAmount > 0)
cout << "Отчеты будут выведены в файл " << filename << endl;
else cout << "Тесты не будут проделаны" << endl;
}
void outputTestAnswer(ofstream& output)
{
if (isSetEmpty(vectorF))
output << "пустое множество";
else
outputSetToFile(vectorF, output);
}
void executeTest()
{
ofstream output;
output.open(filename);
for (int i = 0; i < customTestAmount; i++)
{
fillVectors();
vectorF = 0;
output << "Множество A: ";
outputSetToFile(vectorA, output);
output << endl;
output << "Множество B: ";
outputSetToFile(vectorB, output);
output << endl;
output << "Множество C: ";
outputSetToFile(vectorC, output);
output << endl;
output << "Множество D: ";
outputSetToFile(vectorD, output);
output << endl;
calculateAnswer();
output << "Ответ: F = ";
outputTestAnswer(output);
output << endl;
output << '*' << endl;
}
output.close();
}
int main()
{
setupConsole();
outputGreeting();
input();
while (!isStringCorrect(stringA) || !isStringCorrect(stringB) || !isStringCorrect(stringC) || !isStringCorrect(stringD))
{
cout << "Некорректный ввод" << endl;
input();
}
convertSets();
calculateAnswer();
outputAnswer();
outputDuration();
testInfo();
executeTest();
}

View File

@@ -0,0 +1,31 @@

Microsoft Visual Studio Solution File, Format Version 12.00
# Visual Studio Version 16
VisualStudioVersion = 16.0.31025.194
MinimumVisualStudioVersion = 10.0.40219.1
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "Lab1_1", "Lab1_1.vcxproj", "{8E1DEADF-98BA-4947-9AED-5486C2F7B9F5}"
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
Debug|x64 = Debug|x64
Debug|x86 = Debug|x86
Release|x64 = Release|x64
Release|x86 = Release|x86
EndGlobalSection
GlobalSection(ProjectConfigurationPlatforms) = postSolution
{8E1DEADF-98BA-4947-9AED-5486C2F7B9F5}.Debug|x64.ActiveCfg = Debug|x64
{8E1DEADF-98BA-4947-9AED-5486C2F7B9F5}.Debug|x64.Build.0 = Debug|x64
{8E1DEADF-98BA-4947-9AED-5486C2F7B9F5}.Debug|x86.ActiveCfg = Debug|Win32
{8E1DEADF-98BA-4947-9AED-5486C2F7B9F5}.Debug|x86.Build.0 = Debug|Win32
{8E1DEADF-98BA-4947-9AED-5486C2F7B9F5}.Release|x64.ActiveCfg = Release|x64
{8E1DEADF-98BA-4947-9AED-5486C2F7B9F5}.Release|x64.Build.0 = Release|x64
{8E1DEADF-98BA-4947-9AED-5486C2F7B9F5}.Release|x86.ActiveCfg = Release|Win32
{8E1DEADF-98BA-4947-9AED-5486C2F7B9F5}.Release|x86.Build.0 = Release|Win32
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
EndGlobalSection
GlobalSection(ExtensibilityGlobals) = postSolution
SolutionGuid = {83E70304-D43D-4184-9D07-00854F397EB3}
EndGlobalSection
EndGlobal

View File

@@ -0,0 +1,150 @@
<?xml version="1.0" encoding="utf-8"?>
<Project DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup Label="ProjectConfigurations">
<ProjectConfiguration Include="Debug|Win32">
<Configuration>Debug</Configuration>
<Platform>Win32</Platform>
</ProjectConfiguration>
<ProjectConfiguration Include="Release|Win32">
<Configuration>Release</Configuration>
<Platform>Win32</Platform>
</ProjectConfiguration>
<ProjectConfiguration Include="Debug|x64">
<Configuration>Debug</Configuration>
<Platform>x64</Platform>
</ProjectConfiguration>
<ProjectConfiguration Include="Release|x64">
<Configuration>Release</Configuration>
<Platform>x64</Platform>
</ProjectConfiguration>
</ItemGroup>
<PropertyGroup Label="Globals">
<VCProjectVersion>16.0</VCProjectVersion>
<Keyword>Win32Proj</Keyword>
<ProjectGuid>{8e1deadf-98ba-4947-9aed-5486c2f7b9f5}</ProjectGuid>
<RootNamespace>Lab11</RootNamespace>
<WindowsTargetPlatformVersion>10.0</WindowsTargetPlatformVersion>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">
<ConfigurationType>Application</ConfigurationType>
<UseDebugLibraries>true</UseDebugLibraries>
<PlatformToolset>v142</PlatformToolset>
<CharacterSet>Unicode</CharacterSet>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration">
<ConfigurationType>Application</ConfigurationType>
<UseDebugLibraries>false</UseDebugLibraries>
<PlatformToolset>v142</PlatformToolset>
<WholeProgramOptimization>true</WholeProgramOptimization>
<CharacterSet>Unicode</CharacterSet>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="Configuration">
<ConfigurationType>Application</ConfigurationType>
<UseDebugLibraries>true</UseDebugLibraries>
<PlatformToolset>v142</PlatformToolset>
<CharacterSet>Unicode</CharacterSet>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">
<ConfigurationType>Application</ConfigurationType>
<UseDebugLibraries>false</UseDebugLibraries>
<PlatformToolset>v142</PlatformToolset>
<WholeProgramOptimization>true</WholeProgramOptimization>
<CharacterSet>Unicode</CharacterSet>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
<ImportGroup Label="ExtensionSettings">
</ImportGroup>
<ImportGroup Label="Shared">
</ImportGroup>
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
</ImportGroup>
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
</ImportGroup>
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
</ImportGroup>
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
</ImportGroup>
<PropertyGroup Label="UserMacros" />
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
<LinkIncremental>true</LinkIncremental>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<LinkIncremental>false</LinkIncremental>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
<LinkIncremental>true</LinkIncremental>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
<LinkIncremental>false</LinkIncremental>
</PropertyGroup>
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
<ClCompile>
<WarningLevel>Level3</WarningLevel>
<SDLCheck>true</SDLCheck>
<PreprocessorDefinitions>WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>
<ConformanceMode>true</ConformanceMode>
</ClCompile>
<Link>
<SubSystem>Console</SubSystem>
<GenerateDebugInformation>true</GenerateDebugInformation>
</Link>
</ItemDefinitionGroup>
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<ClCompile>
<WarningLevel>Level3</WarningLevel>
<FunctionLevelLinking>true</FunctionLevelLinking>
<IntrinsicFunctions>true</IntrinsicFunctions>
<SDLCheck>true</SDLCheck>
<PreprocessorDefinitions>WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>
<ConformanceMode>true</ConformanceMode>
</ClCompile>
<Link>
<SubSystem>Console</SubSystem>
<EnableCOMDATFolding>true</EnableCOMDATFolding>
<OptimizeReferences>true</OptimizeReferences>
<GenerateDebugInformation>true</GenerateDebugInformation>
</Link>
</ItemDefinitionGroup>
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
<ClCompile>
<WarningLevel>Level3</WarningLevel>
<SDLCheck>true</SDLCheck>
<PreprocessorDefinitions>_DEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>
<ConformanceMode>true</ConformanceMode>
</ClCompile>
<Link>
<SubSystem>Console</SubSystem>
<GenerateDebugInformation>true</GenerateDebugInformation>
</Link>
</ItemDefinitionGroup>
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
<ClCompile>
<WarningLevel>Level3</WarningLevel>
<FunctionLevelLinking>true</FunctionLevelLinking>
<IntrinsicFunctions>true</IntrinsicFunctions>
<SDLCheck>true</SDLCheck>
<PreprocessorDefinitions>NDEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>
<ConformanceMode>true</ConformanceMode>
</ClCompile>
<Link>
<SubSystem>Console</SubSystem>
<EnableCOMDATFolding>true</EnableCOMDATFolding>
<OptimizeReferences>true</OptimizeReferences>
<GenerateDebugInformation>true</GenerateDebugInformation>
</Link>
</ItemDefinitionGroup>
<ItemGroup>
<ClCompile Include="Lab1_1.cpp" />
</ItemGroup>
<ItemGroup>
<Text Include="Test_result.txt" />
</ItemGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
<ImportGroup Label="ExtensionTargets">
</ImportGroup>
</Project>

View File

@@ -0,0 +1,27 @@
<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup>
<Filter Include="Исходные файлы">
<UniqueIdentifier>{4FC737F1-C7A5-4376-A066-2A32D752A2FF}</UniqueIdentifier>
<Extensions>cpp;c;cc;cxx;c++;cppm;ixx;def;odl;idl;hpj;bat;asm;asmx</Extensions>
</Filter>
<Filter Include="Файлы заголовков">
<UniqueIdentifier>{93995380-89BD-4b04-88EB-625FBE52EBFB}</UniqueIdentifier>
<Extensions>h;hh;hpp;hxx;h++;hm;inl;inc;ipp;xsd</Extensions>
</Filter>
<Filter Include="Файлы ресурсов">
<UniqueIdentifier>{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}</UniqueIdentifier>
<Extensions>rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms</Extensions>
</Filter>
</ItemGroup>
<ItemGroup>
<ClCompile Include="Lab1_1.cpp">
<Filter>Исходные файлы</Filter>
</ClCompile>
</ItemGroup>
<ItemGroup>
<Text Include="Test_result.txt">
<Filter>Файлы ресурсов</Filter>
</Text>
</ItemGroup>
</Project>

View File

@@ -0,0 +1,4 @@
<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="Current" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup />
</Project>

View File

@@ -0,0 +1,60 @@
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> A: CDEHJKMNOTUVWYZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> B: CDEFGHJMQRSUVX
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> C: ACDEJNOPSUVWY
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> D: BEFGHJKLMNOPRTUVYZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: F = FGHKMRTZ
*
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> A: CEFILMRSWY
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> B: BCFIJKNOPRSTVWY
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> C: BDEFIJKMOPQTUXYZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> D: CHLMNSUYZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: F = CLNS
*
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> A: ABCEFGIJKNOQRTUVXYZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> B: GHINPRSXYZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> C: BCHJMNPQRSVWXZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> D: DEGLMNOPQWYZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: F = EGOY
*
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> A: AHIJKMNOPQRSU
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> B: BEFGHIMNOQRSTVWXZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> C: BDEHIJKLOUVXY
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> D: BCDEFLNQSUVWXY
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: F = FNQSW
*
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> A: AEFGJLNPVX
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> B: BFJNOQRTVXY
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> C: EFIJKMNOQRUXYZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> D: MNPRT
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: F = PT
*
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> A: BCDEFHMOPRSTUX
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> B: DEIKPQRTVWZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> C: BCFJKMNOPRSXYZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> D: DHIKLOPQTY
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: F = DHIQT
*
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> A: ABDGIJKMSVWXZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> B: CIMNOPQRSUVW
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> C: BCDFIKNSTUVWY
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> D: CGHIJLMRSUWXYZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: F = GJMRXZ
*
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> A: ABDEHIRSTUWZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> B: ABDGIJLOSTUZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> C: ACEFHLOPTUWX
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> D: CIKNOPQZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: F = IZ
*
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> A: CDEIJLMOQSTUWYZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> B: CFJKLMNOQTUVWXZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> C: AEJKMPRSWZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> D: ABFHIKLMORTY
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: F = FILOTY
*
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> A: AHJLMNUVXYZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> B: BFHIJKLNORTVYZ
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> C: FGJKLNPRSWX
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> D: CHINPQRSTUV
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: F = HITUV
*

View File

@@ -0,0 +1,189 @@
#include <iostream>
#include <fstream>
#include <string>
#include <Windows.h>
#include <cstdio>
#include <time.h>
using namespace std;
const int length = 32;
const char universum[] = "АБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯ";
char stringA[length];
char stringB[length];
char stringC[length];
char stringD[length];
bool vectorA[length], vectorB[length], vectorC[length], vectorD[length], vectorF[length];
double firstTimePoint, lastTimePoint, totalTime = 0;
const char filename[] = "output.txt";
const int testAmount = 10;
void setupConsole()
{
setlocale(LC_ALL, "Russian");
SetConsoleOutputCP(1251);
SetConsoleCP(1251);
}
void outputGreeting()
{
cout << "Программа рассчитывает значение множества F согласно следующим законам - " << endl;
cout << "F = A - (B v C v D), что равносильно F = A - B - C - D." << endl;
cout << "Универсум: " << universum << endl;
}
void input()
{
cout << endl;
cout << "Введите множество A: ";
cin >> stringA;
cout << "Введите множество B: ";
cin >> stringB;
cout << "Введите множество C: ";
cin >> stringC;
cout << "Введите множество D: ";
cin >> stringD;
cout << endl;
}
int memberToIndex(char member)
{
return member - 'А';
}
char indexToMember(int number)
{
return number + 'А';
}
void vectorFromString(bool*vector, const char string[])
{
for (int i = 0; string[i]; i++)
vector[memberToIndex(string[i])] = 1;
};
void convertSets()
{
vectorFromString(vectorA, stringA);
vectorFromString(vectorB, stringB);
vectorFromString(vectorC, stringC);
vectorFromString(vectorD, stringD);
}
void calculateAnswer()
{
for (int i = 0; i < length; i++)
vectorF[i] = (vectorA[i] && !vectorB[i] && !vectorC[i] && !vectorD[i]);
}
void outputSetToConsole(bool(&vector)[length])
{
for (int i = 0; i < length; ++i)
if (vector[i])
cout << indexToMember(i);
}
void outputSetToFile(bool(&vector)[length], ofstream& output)
{
for (int i = 0; i < length; ++i)
if (vector[i])
output << indexToMember(i);
}
void executeTask()
{
convertSets();
calculateAnswer();
}
void outputAnswer()
{
cout << "Ответ: F = ";
outputSetToConsole(vectorF);
cout << endl;
}
int factorial(int number)
{
int factorial = 1;
for (int i = 1; i <= number; i++)
factorial *= number;
return factorial;
}
bool randomBool()
{
return rand() % 2;
}
void fillVectors()
{
for (int i = 0; i < length; i++)
{
vectorA[i] = randomBool();
vectorB[i] = randomBool();
vectorC[i] = randomBool();
vectorD[i] = randomBool();
}
}
void clearAnswerVector()
{
for (int i = 0; i < length; i++)
vectorF[i] = 0;
}
void executeTest()
{
ofstream output;
output.open(filename);
for (int i = 0; i < testAmount; i++)
{
fillVectors();
clearAnswerVector();
output << "Множество A: ";
outputSetToFile(vectorA, output);
output << endl;
output << "Множество B: ";
outputSetToFile(vectorB, output);
output << endl;
output << "Множество C: ";
outputSetToFile(vectorC, output);
output << endl;
output << "Множество D: ";
outputSetToFile(vectorD, output);
output << endl;
firstTimePoint = clock();
calculateAnswer();
lastTimePoint = clock();
totalTime += lastTimePoint - firstTimePoint;
output << "Ответ: F = ";
outputSetToFile(vectorF, output);
output << endl;
output << '*' << endl;
}
output.close();
}
void outputTestInfo()
{
cout << endl;
cout << "- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -" << endl;
cout << "Из 33 символов может быть составлено " << factorial(length) << " перестановок" << endl;
cout << "Программой будут рассмотрены лишь " << testAmount << " случайных комбинаций" << endl;
cout << "Отчеты будут выведены в файл output.txt" << endl;
cout << "На выполнение алгоритма уходит " << totalTime / 1000 << " секунд." << endl;
}
int main()
{
setupConsole();
outputGreeting();
input();
executeTask();
outputAnswer();
executeTest();
outputTestInfo();
}