26课课后题答案疑问
本帖最后由 wow7jiao 于 2018-6-28 14:31 编辑#include <stdio.h>
int main()
{
char str;
char *p = str; // 用于间接寻址
char *pos = {0};// 记录每个单词的地址
int len = 0;
int cChar = 0, cWord = 0; // cChar 统计字符数, cWord 统计单词数
int max = 0, i = 0, j;
printf("请输入一个英文句子:");
// 接收输入,顺带统计用户实际输入了多少个字符
while ((str = getchar()) != '\n' && len + 1 < 1024)//<--------------------请问这里len+1<1024是不是错了,len++是后缀运算,已经自增了直接写成len < 1024就可以了
;
str = '\0'; // str存放的是'\n',将其替换为'\0'
if (*p != ' ')
{
pos = p; // 记录第一个单词的地址
cWord++;
}
while (len--)
{
if (*p++ == ' ')
{
// 判断最大字符数
max = cChar > max ? cChar : max;
cChar = 0;
// 到底了,退出循环
if (*p == '\0')
{
break;
}
// 单词数加一
if (*p != ' ')
{
pos = p;
cWord++;
}
}
else // 没有else会把空格统计进去
{
cChar++;
}
}
max = --cChar > max ? cChar : max; // 最后会算多一个'\0',所以减去
// 申请可变长数组,max+1,否则'\0'放不下
char result;
// 将分割好的单词放进二维数组里
for (i = 0; i < cWord; i++)
{
for (j = 0; *(pos+j) != ' ' && *(pos+j) != '\0'; j++)
{
result = *(pos+j);
}
result = '\0';
}
// 打印结果
printf("分割结果已存放到result[%d][%d]的二维数组中...\n", cWord, max+1);
printf("现在依次打印每个单词:\n");
for (i = 0; i < cWord; i++)
{
printf("%s\n", result);
}
return 0;
} char str; 0-1023
str 1023 + 1 < 1024
str = '\0'; // 比1023少了位
所以结论是,不用len+1 长度是1024,所以索引只能到1023,最后还要留一个位置给 '\0',所以判断条件为 len<1024-2 1024太大了,不方便测试,我们改成10
补两张
BngThea 发表于 2018-6-28 14:41
长度是1024,所以索引只能到1023,最后还要留一个位置给 '\0',所以判断条件为 len
str就是留给'\0' 最后一个位置,所以len可以=1023,len 可以<=1023 wow7jiao 发表于 2018-6-28 15:07
str就是留给'\0' 最后一个位置,所以len可以=1023,len 可以
如果不减一,那str还能存放一个字符 BngThea 发表于 2018-6-28 15:23
如果不减一,那str还能存放一个字符
放了字符,str=‘0’,这个字符就被替换了。
页:
[1]