d975421647 发表于 2019-10-8 16:05:46

c语言s1e19课后习题看不懂,求大佬讲解

#include <stdio.h>
#include <string.h>

#define NUM 128

int main()
{
      int ch, i, j = 0, max = 0;
      int input_num = 0;
      int ascii = {0};
      char count = "";

      printf("请输入英文文本:");

      while ((ch = getchar()) != '\n')
      {
                ascii++; // 字符对应的ASCII码加1
                input_num++;
      }

      for (i = 0; i < NUM; i++)
      {
                if (ascii)
                {
                        count = i;
                        if (ascii > ascii)
                        {
                              max = i;
                        }
                }
      }

      printf("你总共输入了%d个字符,其中不同的字符个数有%d个。\n", input_num, strlen(count));
      printf("它们是:%s\n", count);
      printf("出现次数最多的字符是\'%c\',它总共出现了%d次。\n", max, ascii);

      return 0;
}




这里面的
while ((ch = getchar()) != '\n')
      {
                ascii++; // 字符对应的ASCII码加1
                input_num++;
      }

如果我第一个字符输入a,那么ascii=a,   ascii++是个什么意思,为什么会让字符对应的ASCII码加1{:10_266:}

jackz007 发表于 2019-10-8 16:34:49

本帖最后由 jackz007 于 2019-10-8 18:30 编辑

      字符都有 ASCII 编码,比如,'a' 的编码是 97,'b' 的编码是 98,'z' 的编码是 122,就是说,这些编码都是整型数。

      int ascii = {0},定义了一个足够大容量的整形数组 ascii[],作为全部 128 个 ascii 码的统计空间,并把数组的全部元素初始化为 0。

      本代码就是在键入字符的过程中,利用字符本身的 ascii 编码为下标,通过记录不同字符的出现次数,实现对各个字符出现频率的完整统计,比如,当字符 'a' 出现一次的时候,就让 ascii['a'] 也就是 ascii 的值加 1,最后,从整个数组 ascii[] 中,找到数值最大的元素,输出这个字符和频率值就达到目的了。

      通过下面的代码就可以直观地看到整型数与字符之间的关系。
#include <stdio.h>

main(void)
{
      int k                                                   ;
      for(k = 0 ; k < 128 ; k ++) printf("%3d -> %c\n" , k , k) ;
}

d975421647 发表于 2019-10-9 09:31:26

{:10_256:}谢大佬,回答了两遍。
页: [1]
查看完整版本: c语言s1e19课后习题看不懂,求大佬讲解