//3. (****)有一段文本,将文本中的所有单词,存放到一个字符串数组中。 (要求占用内存最少)
char *array = "There are 5 sb in my class, one of them is yy!";//定义一个字符串数组,写一段文本
printf("%s\n", array);//打印数组测试后面结果
char *temp = array;//定义一个指针用来后面的循环遍历操作
int sum1 = 0;//定义两个累加器 sum1为array的长度
int sum2 = 0;//sum2为dest的长度
//循环得出array长度
while (*temp != '\0') {
sum1++;
temp++;
}
printf("%d\n", sum1);
temp = array;
//循环得出dest长度
while (*temp != '\0') {
if (((*temp >= 'A') && (*temp <= 'Z')) || ((*temp >= 'a') && (*temp <= 'z'))) {
sum2++;
}
temp++;
}
printf("%d\n", sum2);
//定义一个dest字符串数组存储所有单词
int sum3 = 0;//j为dest的下标
temp = array;
while (*temp != '\0') {
if (((*temp < 'A') || ((*temp > 'Z') && (*temp < 'a')) || (*temp > 'z')) && (((*(temp + 1) >= 'A') && (*(temp + 1) <= 'Z')) || ((*(temp + 1) >= 'a') && (*(temp + 1) <= 'z')))) {
sum3++;
}
temp++;
}
int sum4 = sum3 + 1;
printf("%d\n", sum4);
sum3 = 0;
int sum5 = 0;
char **dest = malloc(sizeof(char) * sum2 + sum4);
for (int i = 0; i < sum1; i++) {
if (((array[i] < 'A') || ((array[i] > 'Z') && (array[i] < 'a')) || (array[i] > 'z')) && (((array[i + 1] >= 'A') && (array[i + 1] <= 'Z')) || ((array[i + 1] >= 'a') && (array[i + 1] <= 'z')))) {
sum3++;
sum5 = 0;
}else if((((array[i] >= 'A') && (array[i] <= 'Z')) || ((array[i] >= 'a') && (array[i] <= 'z')))){
dest[sum3][sum5] = array[i];
sum5++;
}
}