S1E26课后作业代码问题
#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)
;
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;
}
这里面if (*p == '\0')// 到底了,退出循环,不是嵌套在if (*p++ == ' ')里面吗?但是如果到底了的'\0'的话,前一个指针指向的位置应该是一个字符的位置吧?不应该是空啊,那嵌套在if (*p++ == ' ')里面就不对了吧?这里不太理解 在这段代码中,`p`是一个指向字符的指针。在`while (len--)`循环中,`*p++`表示逐个访问字符串中的字符,并通过`++`操作符将 `p` 指向下一个字符。但是在检查最后一个字符时,因为字符串是以 `\0` 结束的,所以当 `*p == '\0'` 时,我们知道已经到达了字符串的结尾,可以结束循环。
在if语句中判断 `*p++ == ' '`,是用来判断是否遇到了一个空格,如果是,则说明当前单词结束,需要进行相应的处理。
因此,`if (*p == '\0')` 并不是嵌套在 if `(*p++ == ' ')` 中,而是在判断当前字符是否为字符串的结尾。
希望能够帮助您理解这段代码。如果有更多疑问,请随时提问。
以上回复来自 -- ChatGPT(FishC官方接口),如未能正确解答您的问题,请继续追问。 我说说我的看法,这句话是防止你输入语句是最后敲一个空格,所以增加了这个判断,而这程序的while循环本身是通过len不断自减1为0后退出的, if (*p == '\0')只是为了防止后面的单词数记录错误 FishC_GPT 发表于 2023-11-30 15:31
在这段代码中,`p`是一个指向字符的指针。在`while (len--)`循环中,`*p++`表示逐个访问字符串中的字符,并 ...
懂了 又没太懂那把if (*p=='\0')这句放在else里岂不是也可以?或者更符合逻辑吧 疯狗马德森 发表于 2023-11-30 19:24
懂了 又没太懂那把if (*p=='\0')这句放在else里岂不 ...
是的,您可以将 `if (*p == '\0')` 这句放在 `else` 语句中,这样可以更符合逻辑。这样做的话,当判断到当前字符不是空格时,会先增加字符计数 `cChar`,然后再检查是否到达字符串结尾。如果到达了结尾,则退出循环;否则,继续判断下一个字符是否为空格,并进行相应的处理。在这种情况下,每次只会处理一个字符,而不是之前的处理方式,可能会同时处理多个字符。请参考修改后的代码示例:
// ...
while (len--) {
if (*p++ == ' ') {
// 判断最大字符数
max = cChar > max ? cChar : max;
cChar = 0;
// 单词数加一
if (*p != ' ') {
pos = p;
cWord++;
}
} else {
cChar++;
// 到底了,退出循环
if (*p == '\0') {
break;
}
}
}
// ...
这样修改后的代码逻辑更加清晰,符合预期。希望能够帮助到您。如果还有其他问题,请随时提问。
以上回复来自 -- ChatGPT(FishC官方接口),如未能正确解答您的问题,请继续追问。 渔村暮火 发表于 2023-11-30 19:04
我说说我的看法,这句话是防止你输入语句是最后敲一个空格,所以增加了这个判断,而这程序的while循环本身 ...
确实没啥必要啊弄这个if,而且if(*p=='\0')确实就是在if (*p++ == ' ')里啊,怎么GPT说不是在里面的。。 疯狗马德森 发表于 2023-11-30 19:28
确实没啥必要啊弄这个if,而且if(*p=='\0')确实就是 ...
非常抱歉给您造成的困惑,我之前的回答可能有误。您是正确的,`if (*p == '\0')` 是在 `if (*p++ == ' ')` 的嵌套中,用于判断当前字符是否为字符串的结尾。
在代码中,每次循环开始时,先进行 `*p++ == ' '` 的判断,如果当前字符是空格,则执行相应的操作。在这个判断之后,再检查 `*p == '\0'` 是否成立,如果成立则说明已经到达字符串的结尾,可以退出循环。
因此,修改代码将 `if (*p == '\0')` 放在 `else` 语句中,并不符合逻辑。在原来的代码逻辑下,确实不需要单独将 `if (*p == '\0')` 放在 `else` 里面。
再次对我的回答给您带来的困扰表示道歉,希望这次的解答能够更加清晰明了。如果还有其他问题,请随时提问。
以上回复来自 -- ChatGPT(FishC官方接口),如未能正确解答您的问题,请继续追问。 FishC_GPT 发表于 2023-11-30 19:28
非常抱歉给您造成的困惑,我之前的回答可能有误。您是正确的,`if (*p == '\0')` 是在 `if (*p++ == ' ') ...
谢谢我再自己琢磨琢磨 疯狗马德森 发表于 2023-11-30 19:47
谢谢我再自己琢磨琢磨
不客气,如果您有任何其他问题,随时都可以向我提问。祝您在编程学习中取得进展!
以上回复来自 -- ChatGPT(FishC官方接口),如未能正确解答您的问题,请继续追问。
页:
[1]