zxcvbnmasdf 发表于 2021-11-2 15:41:22

S1E26指向指针的指针

想问下第50行
max = --cChar > max ? cChar : max; // 最后会算多一个'\0',所以减去

哪里有多算一个'\0',有没有大佬能解释一下





#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;
}


番杰 发表于 2021-11-2 16:04:07

就是字符串是以 ‘ \0 ’结尾的,
就好比:你输入一个字符串:"switch";
但它在内存中存放的实际是“switch\0”

你这个程序中,用数组去存放字符串,连同‘\0’一起储存,就像程序中16行,以写了把‘\0’写入数组
而且,程序在24行的那个while循环里会把‘\0‘当成一个字符,导致cChar,所以在跳出while后,使cChar减一

zxcvbnmasdf 发表于 2021-11-2 16:51:50

番杰 发表于 2021-11-2 16:04
就是字符串是以 ‘ \0 ’结尾的,
就好比:你输入一个字符串:"switch";
但它在内存中存放的实际是“swi ...

那想问下这个多算一个‘\0’,是不是在最后一个字符不是空格的时候才成立?
如果最后一个字符是空格,是不是就进入了35行的break语句,然后这时候cChar为0

番杰 发表于 2021-11-2 16:58:50

zxcvbnmasdf 发表于 2021-11-2 16:51
那想问下这个多算一个‘\0’,是不是在最后一个字符不是空格的时候才成立?
如果最后一个字符是空格,是 ...

对,是的,

番杰 发表于 2021-11-2 17:10:28

zxcvbnmasdf 发表于 2021-11-2 16:51
那想问下这个多算一个‘\0’,是不是在最后一个字符不是空格的时候才成立?
如果最后一个字符是空格,是 ...

就是分了两种结尾;(以下划线:“_”代替表示:“空格” )

(1)以’_\0 ‘结尾,以空格结尾
例如输入“asd_\0”
这种情况下在进入到if(*p++ == '_')的程序中,max = 3(asd三个字符)cchar被赋值为0;
p指向\0,break;
所以跳出循环后--cChar 无论如何都不会大于 max,除非 你只输入一个空格。

(2)以’字符\0 ‘结尾,即以字符结尾
例如输入“asd\0”
这个时候 cChar在就计算时会多加一个\0,所以退出循环后要减去;

另,这种结尾方式,退出while是因为len减到了0;

zxcvbnmasdf 发表于 2021-11-2 17:48:07

番杰 发表于 2021-11-2 17:10
就是分了两种结尾;(以下划线:“_”代替表示:“空格” )

(1)以’_\0 ‘结尾,以空格 ...

好的,懂了,谢谢大佬!
页: [1]
查看完整版本: S1E26指向指针的指针