林永吉的Algorithm库
Nie możesz wybrać więcej, niż 25 tematów Tematy muszą się zaczynać od litery lub cyfry, mogą zawierać myślniki ('-') i mogą mieć do 35 znaków.

59 wiersze
2.7 KiB

  1. // pch.cpp: 与预编译标头对应的源文件
  2. #include "pch.h"
  3. int CalcCount(int n, char(*str)[10])
  4. {
  5. TCHAR chSectionNames[2048] = { 0 };//定义一个数组,保存读取节的名字
  6. char* pSectionName; //保存找到的某个节名字符串的首地址
  7. int i = 0; //i指向数组chSectionNames的某个位置,从0开始,顺序后移
  8. int j = 0; //j用来保存下一个节名字符串的首地址相对于当前i的位置偏移量
  9. int k = 0; //临时变量,用于给str数组赋值
  10. int m = 0; //临时变量,用于给str数组赋值
  11. int count = 0; //统计节的个数
  12. GetPrivateProfileSectionNames(chSectionNames, 2048, "..//ex1.ini");//获取文件中的节名,每个节名以"\0"分割,保存在chSectionNames中
  13. //要加头文件
  14. for (i = 0; i < 2048; i++, j++)//对chSectionName中保存的内容进行拆分
  15. {
  16. if (chSectionNames[0] == '\0')//如果第一个字符就是0,则说明ini中一个节也没有,
  17. {
  18. break;
  19. }
  20. if (chSectionNames[i] == '\0')
  21. {
  22. count++;
  23. pSectionName = &chSectionNames[i - j]; //找到一个0,则说明从这个字符往前,减掉j个偏移量,
  24. //就是一个节名的首地址
  25. j = -1; //找到一个节名后,j的值要还原,以统计下一个节名地址的偏移量
  26. //赋成-1是因为节名字符串的最后一个字符0是终止符,不能作为节名
  27. for (m = 0; m <= strlen(pSectionName); m++)//把找到的节名保存到str中
  28. {
  29. str[k][m] = *(pSectionName + m);
  30. }
  31. //str[k][++m] = '\0';//手动给节名加上\0,表示这个节名结束
  32. k++;//变量自加,用来保存下一个节名
  33. //在获取节名的时候可以获取该节中键的值,前提是我们知道该节中有哪些键。
  34. if (chSectionNames[i + 1] == 0)
  35. {
  36. break; //当两个相邻的字符都是0时,则所有的节名都已找到,循环终止
  37. }
  38. }
  39. }
  40. return count;//返回节名的个数
  41. }
  42. int* str_device(CString* str, int* value_count)
  43. {
  44. char* token; //存放被切割后的第一个子串
  45. static int Section_devide[500];//存放字符切割完成以后的数组元素值
  46. char Section_value[500] = { 0 };//存放nums转换成string类型的结果
  47. strcpy(Section_value, *str);//将CString类型的字符串转换成char类型,方便后面切割字符串
  48. //获得切割到的第一个字符串
  49. token = strtok(Section_value, ",");
  50. /* 继续获取其他的子字符串 */
  51. while (token != NULL) {
  52. Section_devide[*value_count] = (_ttoi)(token);//把切割得到的子串转为int,存到数组中去。
  53. token = strtok(NULL, ",");
  54. (*value_count)++; //记录存了多少个元素
  55. }
  56. return Section_devide; //返回数组首地址
  57. }