From 5e2d3bb913cad6ba9c92531eb82758ccce232bfa Mon Sep 17 00:00:00 2001 From: Andrew Kalinin Date: Wed, 18 Dec 2024 14:52:05 +0300 Subject: [PATCH] add: solution --- .../firstTask(fromBinaryToDecimal).c | 53 +++++++ .../firstTask(fromBinaryToDecimal).sln | 31 ++++ .../firstTask(fromBinaryToDecimal).vcxproj | 135 ++++++++++++++++++ 3 files changed, 219 insertions(+) create mode 100644 test(3)/firstTask(fromBinaryToDecimal)/firstTask(fromBinaryToDecimal).c create mode 100644 test(3)/firstTask(fromBinaryToDecimal)/firstTask(fromBinaryToDecimal).sln create mode 100644 test(3)/firstTask(fromBinaryToDecimal)/firstTask(fromBinaryToDecimal).vcxproj diff --git a/test(3)/firstTask(fromBinaryToDecimal)/firstTask(fromBinaryToDecimal).c b/test(3)/firstTask(fromBinaryToDecimal)/firstTask(fromBinaryToDecimal).c new file mode 100644 index 0000000..4c6d30f --- /dev/null +++ b/test(3)/firstTask(fromBinaryToDecimal)/firstTask(fromBinaryToDecimal).c @@ -0,0 +1,53 @@ +#define _CRT_SECURE_NO_WARNINGS + +#include +#include +#include + +int convert(const char* binaryString) { + int decimal = 0; + int length = strlen(binaryString); + for (int i = 0; i < length; ++i) { + decimal = decimal * 2; + if (binaryString[i] == '1') { + decimal += 1; + } + } + return decimal; +} + +void decimalToString(int decimal, char* decimalString) { + sprintf(decimalString, "%d", decimal); +} + +bool test() { + char firstTestBinaryString[10] = "11011"; + int firstTestDecimal = convert(firstTestBinaryString); + + char secondTestBinaryString[10] = "001110"; + int secondTestDecimal = convert(secondTestBinaryString); + + char thirdTestBinaryString[10] = "11011111"; + int thirdTestDecimal = convert(thirdTestBinaryString); + + if (firstTestDecimal != 27 || secondTestDecimal != 14 || thirdTestDecimal != 223) { + return false; + } + return true; +} + + +int main(void) { + if (!test()) { + printf("Test failed"); + return -1; + } + char binaryString[100] = "101110"; + int decimal = convert(binaryString); + + char decimalString[100] = " "; + decimalToString(decimal, decimalString); + + printf("binary representation: %s\n\n", binaryString); + printf("decimal representation: %s\n\n", decimalString); +} \ No newline at end of file diff --git a/test(3)/firstTask(fromBinaryToDecimal)/firstTask(fromBinaryToDecimal).sln b/test(3)/firstTask(fromBinaryToDecimal)/firstTask(fromBinaryToDecimal).sln new file mode 100644 index 0000000..6f905de --- /dev/null +++ b/test(3)/firstTask(fromBinaryToDecimal)/firstTask(fromBinaryToDecimal).sln @@ -0,0 +1,31 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.11.35222.181 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "firstTask(fromBinaryToDecimal)", "firstTask(fromBinaryToDecimal).vcxproj", "{8263470C-7D4F-4B14-B323-5F156C6C0471}" +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 + {8263470C-7D4F-4B14-B323-5F156C6C0471}.Debug|x64.ActiveCfg = Debug|x64 + {8263470C-7D4F-4B14-B323-5F156C6C0471}.Debug|x64.Build.0 = Debug|x64 + {8263470C-7D4F-4B14-B323-5F156C6C0471}.Debug|x86.ActiveCfg = Debug|Win32 + {8263470C-7D4F-4B14-B323-5F156C6C0471}.Debug|x86.Build.0 = Debug|Win32 + {8263470C-7D4F-4B14-B323-5F156C6C0471}.Release|x64.ActiveCfg = Release|x64 + {8263470C-7D4F-4B14-B323-5F156C6C0471}.Release|x64.Build.0 = Release|x64 + {8263470C-7D4F-4B14-B323-5F156C6C0471}.Release|x86.ActiveCfg = Release|Win32 + {8263470C-7D4F-4B14-B323-5F156C6C0471}.Release|x86.Build.0 = Release|Win32 + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {9315E425-C230-49FB-991B-89A956EB9022} + EndGlobalSection +EndGlobal diff --git a/test(3)/firstTask(fromBinaryToDecimal)/firstTask(fromBinaryToDecimal).vcxproj b/test(3)/firstTask(fromBinaryToDecimal)/firstTask(fromBinaryToDecimal).vcxproj new file mode 100644 index 0000000..643f5a5 --- /dev/null +++ b/test(3)/firstTask(fromBinaryToDecimal)/firstTask(fromBinaryToDecimal).vcxproj @@ -0,0 +1,135 @@ + + + + + Debug + Win32 + + + Release + Win32 + + + Debug + x64 + + + Release + x64 + + + + 17.0 + Win32Proj + {8263470c-7d4f-4b14-b323-5f156c6c0471} + firstTaskfromBinaryToDecimal + 10.0 + + + + Application + true + v143 + Unicode + + + Application + false + v143 + true + Unicode + + + Application + true + v143 + Unicode + + + Application + false + v143 + true + Unicode + + + + + + + + + + + + + + + + + + + + + + Level3 + true + WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions) + true + + + Console + true + + + + + Level3 + true + true + true + WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions) + true + + + Console + true + true + true + + + + + Level3 + true + _DEBUG;_CONSOLE;%(PreprocessorDefinitions) + true + + + Console + true + + + + + Level3 + true + true + true + NDEBUG;_CONSOLE;%(PreprocessorDefinitions) + true + + + Console + true + true + true + + + + + + + + + \ No newline at end of file