@@ -56,3 +56,38 @@ Alogrithm/.vs/Alogrithm/v16/Browse.VC.db-wal | |||||
Alogrithm/.vs/Alogrithm/v16/Browse.VC.opendb | Alogrithm/.vs/Alogrithm/v16/Browse.VC.opendb | ||||
Alogrithm/.vs/Alogrithm/v16/Solution.VC.db-shm | Alogrithm/.vs/Alogrithm/v16/Solution.VC.db-shm | ||||
Alogrithm/.vs/Alogrithm/v16/Solution.VC.db-wal | Alogrithm/.vs/Alogrithm/v16/Solution.VC.db-wal | ||||
Alogrithm/TestResults/fb202b31-a40d-4970-8414-add42e85ae22/林_MI-1 2021-01-14 16_23_23.coverage | |||||
Alogrithm/UnitTest/Debug/UnitTest.Build.CppClean.log | |||||
Alogrithm/UnitTest/Debug/UnitTest.dll.recipe | |||||
Alogrithm/UnitTest/Debug/UnitTest.obj | |||||
Alogrithm/UnitTest/Debug/UnitTest.vcxproj.FileListAbsolute.txt | |||||
Alogrithm/UnitTest/Debug/UnitTest.tlog/link.12728.delete.1.tlog | |||||
Alogrithm/UnitTest/Debug/UnitTest.tlog/link.command.1.tlog | |||||
Alogrithm/UnitTest/Debug/UnitTest.tlog/link.read.1.tlog | |||||
Alogrithm/UnitTest/Debug/UnitTest.tlog/link.write.1.tlog | |||||
Alogrithm/UnitTest/Debug/UnitTest.tlog/UnitTest.write.1u.tlog | |||||
Alogrithm/TestResults/84c6ace1-133c-41c3-9b02-94db81e6aa3a/林_MI-1 2021-01-14 18_54_25.coverage | |||||
Alogrithm/TestResults/8b615f86-7689-4378-a8a0-e09120490e1d/林_MI-1 2021-01-14 15_48_38.coverage | |||||
Alogrithm/TestResults/8e613af4-68a7-4f48-8525-48d0cd2c3928/林_MI-1 2021-01-14 18_36_56.coverage | |||||
Alogrithm/TestResults/8fda7b28-3ed2-4ea0-bf3c-5a9a28ea695c/林_MI-1 2021-01-14 18_41_23.coverage | |||||
Alogrithm/TestResults/a0595beb-6f55-4119-8993-a7004136a5b6/林_MI-1 2021-01-14 15_10_41.coverage | |||||
Alogrithm/TestResults/a556f927-382c-4f2c-b2c7-5fe00c31dcb5/林_MI-1 2021-01-14 16_21_32.coverage | |||||
Alogrithm/TestResults/c6594eae-705b-4566-9bda-127da6acb938/林_MI-1 2021-01-14 15_15_47.coverage | |||||
Alogrithm/TestResults/cce6119d-a3de-446e-95bc-b2f5f83123cb/林_MI-1 2021-01-14 16_22_04.coverage | |||||
Alogrithm/TestResults/cee69d67-755c-4b31-8eec-9107e82975bc/林_MI-1 2021-01-14 15_48_01.coverage | |||||
Alogrithm/TestResults/e0dd8071-2170-417d-9549-6021400ffa4b/林_MI-1 2021-01-14 18_38_32.coverage | |||||
Alogrithm/TestResults/03c6f374-8594-4b77-ba6c-eb0b342ba092/林_MI-1 2021-01-14 16_21_54.coverage | |||||
Alogrithm/TestResults/0ff3c1ff-496e-4801-9b05-b4b37d173d29/林_MI-1 2021-01-14 18_35_54.coverage | |||||
Alogrithm/TestResults/180d1d1c-2be8-451c-9447-3035ebbc58c3/林_MI-1 2021-01-14 18_54_12.coverage | |||||
Alogrithm/TestResults/1ace4913-8399-4b21-ba73-ecb59f5c0e16/林_MI-1 2021-01-14 15_12_41.coverage | |||||
Alogrithm/TestResults/327189f3-d0cc-4bd4-baef-11656043e1fb/林_MI-1 2021-01-14 16_22_20.coverage | |||||
Alogrithm/TestResults/5e078520-30dd-446b-ae53-875962257cfe/林_MI-1 2021-01-14 16_22_28.coverage | |||||
Alogrithm/TestResults/664ef07b-ae35-4d96-9a2b-2ef0e924c550/林_MI-1 2021-01-14 16_21_42.coverage | |||||
Alogrithm/TestResults/6b39ec81-5639-4a8b-8905-11278c842fa8/林_MI-1 2021-01-14 18_38_46.coverage | |||||
Alogrithm/TestResults/72ff8dca-92fc-4877-b1c8-1aedc3802082/林_MI-1 2021-01-14 15_11_48.coverage | |||||
Alogrithm/TestResults/73ea4536-5f55-4a46-991b-139ffea8ade3/林_MI-1 2021-01-14 18_41_17.coverage | |||||
Alogrithm/Debug/UnitTest.dll | |||||
Alogrithm/Debug/UnitTest.exp | |||||
Alogrithm/Debug/UnitTest.ilk | |||||
Alogrithm/Debug/UnitTest.lib | |||||
Alogrithm/Debug/UnitTest.pdb |
@@ -92,6 +92,7 @@ | |||||
<Link> | <Link> | ||||
<SubSystem>Console</SubSystem> | <SubSystem>Console</SubSystem> | ||||
<GenerateDebugInformation>true</GenerateDebugInformation> | <GenerateDebugInformation>true</GenerateDebugInformation> | ||||
<AdditionalDependencies>../Alogrithm/Debug/2_ExcelSheetColumnTitle.obj;%(AdditionalDependencies)</AdditionalDependencies> | |||||
</Link> | </Link> | ||||
</ItemDefinitionGroup> | </ItemDefinitionGroup> | ||||
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> | <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> | ||||
@@ -150,6 +151,8 @@ | |||||
<ClInclude Include="include\3_bool IsUgly.h" /> | <ClInclude Include="include\3_bool IsUgly.h" /> | ||||
</ItemGroup> | </ItemGroup> | ||||
<ItemGroup> | <ItemGroup> | ||||
<None Include="config\1_ContainsNearbyDuplicate.ini" /> | |||||
<None Include="config\2_ExcelSheetColumnTiTle.ini" /> | |||||
<None Include="config\3_bool IsUgly.ini" /> | <None Include="config\3_bool IsUgly.ini" /> | ||||
</ItemGroup> | </ItemGroup> | ||||
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" /> | <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" /> | ||||
@@ -52,5 +52,11 @@ | |||||
<None Include="config\3_bool IsUgly.ini"> | <None Include="config\3_bool IsUgly.ini"> | ||||
<Filter>资源文件\config</Filter> | <Filter>资源文件\config</Filter> | ||||
</None> | </None> | ||||
<None Include="config\1_ContainsNearbyDuplicate.ini"> | |||||
<Filter>资源文件\config</Filter> | |||||
</None> | |||||
<None Include="config\2_ExcelSheetColumnTiTle.ini"> | |||||
<Filter>资源文件\config</Filter> | |||||
</None> | |||||
</ItemGroup> | </ItemGroup> | ||||
</Project> | </Project> |
@@ -1,11 +1,23 @@ | |||||
[Test1] | [Test1] | ||||
nums=1,2,3,1 | |||||
nExpect=1 | |||||
[Test1] | |||||
nums=1,0,1,1 | |||||
nExpect=1 | |||||
array=1,2,3,1 | |||||
key=3 | |||||
output=1 | |||||
[Test2] | |||||
array=1,0,1,1 | |||||
key=1 | |||||
output=1 | |||||
[Test3] | [Test3] | ||||
nums=1,2,3,1,2,3 | |||||
nExpect=0 | |||||
array=1,2,3,1,2,3 | |||||
key=2 | |||||
output=0 | |||||
[Test4] | |||||
array=1,2,3,1,2,3 | |||||
key=3 | |||||
output=1 | |||||
[Test5] | |||||
array=1,0,3,4,2,1,0,3,4 | |||||
key=3 | |||||
output=0 | |||||
@@ -0,0 +1,21 @@ | |||||
[Test1] | |||||
Na=1 | |||||
nExpect=A | |||||
[Test2] | |||||
Na=2 | |||||
nExpect=B | |||||
[Test3] | |||||
Na=26 | |||||
nExpect=Z | |||||
[Test4] | |||||
Na=1 | |||||
nExpect=A | |||||
[Test5] | |||||
Na=27 | |||||
nExpect=AA | |||||
[Test6] | |||||
Na=52 | |||||
nExpect=AZ | |||||
[Test7] | |||||
Na=53 | |||||
nExpect=AAA |
@@ -0,0 +1,15 @@ | |||||
[Test1] | |||||
Na=6 | |||||
nExpect=1 | |||||
[Test2] | |||||
Na=3 | |||||
nExpect=1 | |||||
[Test3] | |||||
Na=14 | |||||
nExpect=0 | |||||
[Test4] | |||||
Na=15 | |||||
nExpect=1 | |||||
[Test5] | |||||
Na=20 | |||||
nExpect=1 |
@@ -3,7 +3,7 @@ | |||||
//给定一个整数,返回它在 Excel 表中相对应的列名称,如果在Excel表中找不到该列,则返回""。 | //给定一个整数,返回它在 Excel 表中相对应的列名称,如果在Excel表中找不到该列,则返回""。 | ||||
char* ExcelSheetColumnTitle(int n) | char* ExcelSheetColumnTitle(int n) | ||||
{ | { | ||||
char str[STR_LEN] = { 0 }; | |||||
static char str[STR_LEN] = { 0 }; | |||||
int i = 0; | int i = 0; | ||||
while (n > 0) { | while (n > 0) { | ||||
if ((n > 0) && (n <= 26)) { | if ((n > 0) && (n <= 26)) { | ||||
@@ -15,6 +15,6 @@ char* ExcelSheetColumnTitle(int n) | |||||
n = n - 26; | n = n - 26; | ||||
i++; | i++; | ||||
} | } | ||||
printf("%s", str); | |||||
return str; | |||||
char* pstr = str; | |||||
return pstr; | |||||
} | } |
@@ -1,18 +1,60 @@ | |||||
#include "pch.h" | #include "pch.h" | ||||
#include "CppUnitTest.h" | #include "CppUnitTest.h" | ||||
#define FilePath "../Alogrithm/1_ContainsNearbyDuplicate.ini" | |||||
using namespace Microsoft::VisualStudio::CppUnitTestFramework; | using namespace Microsoft::VisualStudio::CppUnitTestFramework; | ||||
#define FileName_1 "../Alogrithm/config/1_ContainsNearbyDuplicate.ini" | |||||
#define FileName_2 "../Alogrithm/config/2_ExcelSheetColumnTiTle.ini" | |||||
#define FileName_3 "../Alogrithm/config/3_bool IsUgly.ini" | |||||
namespace UnitTest | namespace UnitTest | ||||
{ | { | ||||
TEST_CLASS(UnitTest) | |||||
TEST_CLASS(UnitTest_1) | |||||
{ | { | ||||
public: | |||||
TEST_METHOD(TestMethode2) | |||||
TEST_METHOD(TestMethode1) | |||||
{ | { | ||||
char Section_Name[100][10] = { 0 }; | |||||
int Section_Count = CalcCount(100, Section_Name, FileName_1); | |||||
int array_count = 0; | |||||
int* Section_Value; | |||||
CString Na, Nb, nExpect; | |||||
for (int i = 0; i < Section_Count; i++) { | |||||
GetPrivateProfileString(Section_Name[i], "array", " ", Na.GetBuffer(200), 200, FileName_1); | |||||
GetPrivateProfileString(Section_Name[i], "key", " ", Nb.GetBuffer(20), 20, FileName_1); | |||||
GetPrivateProfileString(Section_Name[i], "output", " ", nExpect.GetBuffer(20), 20, FileName_1); | |||||
Section_Value = str_device(Na, &array_count); | |||||
bool nReal = ContainsNearbyDuplicate(Section_Value, array_count, _ttoi(Nb)); | |||||
Assert::AreEqual(nReal, CstrToBool(nExpect)); | |||||
} | |||||
} | } | ||||
}; | }; | ||||
TEST_CLASS(UnitTest_2) | |||||
{ | |||||
TEST_METHOD(TestMethode1) | |||||
{ | |||||
char Section_Name[100][10] = { 0 }; | |||||
int Section_Count = CalcCount(100, Section_Name, FileName_2); | |||||
CString Na, nExpect; | |||||
for (int i = 0; i < Section_Count; i++) { | |||||
GetPrivateProfileString(Section_Name[i], "Na", " ", Na.GetBuffer(20), 20, FileName_2); | |||||
GetPrivateProfileString(Section_Name[i], "nExpect", " ", nExpect.GetBuffer(100), 100, FileName_2); | |||||
char* nReal = ExcelSheetColumnTitle(_ttoi(Na)); | |||||
Assert::AreEqual(*nReal, *nExpect); | |||||
} | |||||
} | |||||
}; | |||||
TEST_CLASS(UnitTest_3) | |||||
{ | |||||
TEST_METHOD(TestMethode3) | |||||
{ | |||||
char Section_Name[100][10] = { 0 }; | |||||
int Section_Count = CalcCount(100, Section_Name, FileName_3); | |||||
CString Na, nExpect; | |||||
for (int i = 0; i < Section_Count; i++) { | |||||
GetPrivateProfileString(Section_Name[i], "Na", " ", Na.GetBuffer(20), 20, FileName_3); | |||||
GetPrivateProfileString(Section_Name[i], "nExpect", " ", nExpect.GetBuffer(20), 20, FileName_3); | |||||
bool nReal = IsUgly(_ttoi(Na)); | |||||
Assert::AreEqual(nReal, CstrToBool(nExpect)); | |||||
} | |||||
} | |||||
}; | |||||
} | } |
@@ -93,13 +93,17 @@ | |||||
<WarningLevel>Level3</WarningLevel> | <WarningLevel>Level3</WarningLevel> | ||||
<SDLCheck>true</SDLCheck> | <SDLCheck>true</SDLCheck> | ||||
<AdditionalIncludeDirectories>$(VCInstallDir)UnitTest\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> | <AdditionalIncludeDirectories>$(VCInstallDir)UnitTest\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> | ||||
<PreprocessorDefinitions>WIN32;_DEBUG;%(PreprocessorDefinitions)</PreprocessorDefinitions> | |||||
<PreprocessorDefinitions>WIN32;_DEBUG;_CRT_SECURE_NO_WARNINGS;%(PreprocessorDefinitions)</PreprocessorDefinitions> | |||||
<UseFullPaths>true</UseFullPaths> | <UseFullPaths>true</UseFullPaths> | ||||
<PrecompiledHeaderFile>pch.h</PrecompiledHeaderFile> | <PrecompiledHeaderFile>pch.h</PrecompiledHeaderFile> | ||||
<LanguageStandard>stdcpp14</LanguageStandard> | |||||
<LanguageStandard_C>stdc11</LanguageStandard_C> | |||||
</ClCompile> | </ClCompile> | ||||
<Link> | <Link> | ||||
<SubSystem>Windows</SubSystem> | <SubSystem>Windows</SubSystem> | ||||
<AdditionalLibraryDirectories>$(VCInstallDir)UnitTest\lib;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> | <AdditionalLibraryDirectories>$(VCInstallDir)UnitTest\lib;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> | ||||
<GenerateDebugInformation>DebugFull</GenerateDebugInformation> | |||||
<AdditionalDependencies>../Alogrithm/Debug/1_ContainsNearbyDuplicate.obj;../Alogrithm/Debug/2_ExcelSheetColumnTitle.obj;../Alogrithm/Debug/3_bool IsUgly.obj;%(AdditionalDependencies)</AdditionalDependencies> | |||||
</Link> | </Link> | ||||
</ItemDefinitionGroup> | </ItemDefinitionGroup> | ||||
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> | <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> | ||||
@@ -1,7 +1,13 @@ | |||||
// pch.cpp: 与预编译标头对应的源文件 | // pch.cpp: 与预编译标头对应的源文件 | ||||
#include "pch.h" | #include "pch.h" | ||||
int CalcCount(int n, char(*str)[10]) | |||||
//***************************************************************************************************// | |||||
//********读取ini文件函数,返回值为文件节的个数,入参为字符串数组的首地址,带回读取到的节名***************// | |||||
//***************************************************************************************************// | |||||
int CalcCount(int n, char(*str)[10],const char *FileName) | |||||
{ | { | ||||
TCHAR chSectionNames[2048] = { 0 };//定义一个数组,保存读取节的名字 | TCHAR chSectionNames[2048] = { 0 };//定义一个数组,保存读取节的名字 | ||||
char* pSectionName; //保存找到的某个节名字符串的首地址 | char* pSectionName; //保存找到的某个节名字符串的首地址 | ||||
@@ -10,7 +16,7 @@ int CalcCount(int n, char(*str)[10]) | |||||
int k = 0; //临时变量,用于给str数组赋值 | int k = 0; //临时变量,用于给str数组赋值 | ||||
int m = 0; //临时变量,用于给str数组赋值 | int m = 0; //临时变量,用于给str数组赋值 | ||||
int count = 0; //统计节的个数 | int count = 0; //统计节的个数 | ||||
GetPrivateProfileSectionNames(chSectionNames, 2048, "..//ex1.ini");//获取文件中的节名,每个节名以"\0"分割,保存在chSectionNames中 | |||||
GetPrivateProfileSectionNames(chSectionNames, 2048, FileName);//获取文件中的节名,每个节名以"\0"分割,保存在chSectionNames中 | |||||
//要加头文件 | //要加头文件 | ||||
for (i = 0; i < 2048; i++, j++)//对chSectionName中保存的内容进行拆分 | for (i = 0; i < 2048; i++, j++)//对chSectionName中保存的内容进行拆分 | ||||
{ | { | ||||
@@ -29,7 +35,6 @@ int CalcCount(int n, char(*str)[10]) | |||||
{ | { | ||||
str[k][m] = *(pSectionName + m); | str[k][m] = *(pSectionName + m); | ||||
} | } | ||||
//str[k][++m] = '\0';//手动给节名加上\0,表示这个节名结束 | |||||
k++;//变量自加,用来保存下一个节名 | k++;//变量自加,用来保存下一个节名 | ||||
//在获取节名的时候可以获取该节中键的值,前提是我们知道该节中有哪些键。 | //在获取节名的时候可以获取该节中键的值,前提是我们知道该节中有哪些键。 | ||||
if (chSectionNames[i + 1] == 0) | if (chSectionNames[i + 1] == 0) | ||||
@@ -41,12 +46,19 @@ int CalcCount(int n, char(*str)[10]) | |||||
return count;//返回节名的个数 | return count;//返回节名的个数 | ||||
} | } | ||||
int* str_device(CString* str, int* value_count) | |||||
#if 1 | |||||
//***************************************************************************************************// | |||||
//************切割字符串函数,返回值为int数组的首地址,通过传入int指针带回数组元素个数***************// | |||||
//***************************************************************************************************// | |||||
int* str_device(CString str, int* value_count) | |||||
{ | { | ||||
char* token; //存放被切割后的第一个子串 | char* token; //存放被切割后的第一个子串 | ||||
static int Section_devide[500];//存放字符切割完成以后的数组元素值 | static int Section_devide[500];//存放字符切割完成以后的数组元素值 | ||||
char Section_value[500] = { 0 };//存放nums转换成string类型的结果 | char Section_value[500] = { 0 };//存放nums转换成string类型的结果 | ||||
strcpy(Section_value, *str);//将CString类型的字符串转换成char类型,方便后面切割字符串 | |||||
memset(Section_value, 0, sizeof(char) * 500); | |||||
*value_count = 0; | |||||
strcpy(Section_value, str);//将CString类型的字符串转换成char类型,方便后面切割字符串 | |||||
//获得切割到的第一个字符串 | //获得切割到的第一个字符串 | ||||
token = strtok(Section_value, ","); | token = strtok(Section_value, ","); | ||||
/* 继续获取其他的子字符串 */ | /* 继续获取其他的子字符串 */ | ||||
@@ -56,4 +68,13 @@ int* str_device(CString* str, int* value_count) | |||||
(*value_count)++; //记录存了多少个元素 | (*value_count)++; //记录存了多少个元素 | ||||
} | } | ||||
return Section_devide; //返回数组首地址 | return Section_devide; //返回数组首地址 | ||||
} | |||||
} | |||||
#endif | |||||
bool CstrToBool(CString str) | |||||
{ | |||||
if (str == "1") { | |||||
return 1; | |||||
} | |||||
return 0; | |||||
} |
@@ -13,9 +13,13 @@ | |||||
#include<Windows.h> | #include<Windows.h> | ||||
#include <atlstr.h> | #include <atlstr.h> | ||||
#include"../Alogrithm/include/1_ContainsNearbyDuplicate.h" | |||||
#include"../Alogrithm/include/2_ExcelSheetColumnTitle.h" | |||||
#include"../Alogrithm/include/3_bool IsUgly.h" | |||||
int CalcCount(int n, char(*str)[10]); | |||||
int* str_device(CString* str, int* value_count); | |||||
int CalcCount(int n, char(*str)[10],const char *FileName); | |||||
int* str_device(CString str, int* value_count); | |||||
bool CstrToBool(CString str); | |||||
#endif //PCH_H | #endif //PCH_H |