|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
答案代码如下:
#include <stdio.h>
#include <string.h>
#define NUM 128
int main()
{
int ch, i, j = 0, max = 0;
int input_num = 0;
int ascii[NUM] = {0};
char count[NUM] = "";
printf("请输入英文文本:");
while ((ch = getchar()) != '\n')
{
ascii[ch]++; // 字符对应的ASCII码加1————————————————问题一:这里ASCII码加一的目的是什么,没看懂
input_num++;
}
for (i = 0; i < NUM; i++)————————————————————问题二:这个for语句没看懂,有没有大佬能解释以下,真的非常感谢!
{
if (ascii[i])
{
count[j++] = i;
if (ascii[i] > ascii[max])
{
max = i;
}
}
}
printf("你总共输入了%d个字符,其中不同的字符个数有%d个。\n", input_num, strlen(count));
printf("它们是:%s\n", count);
printf("出现次数最多的字符是\'%c\',它总共出现了%d次。\n", max, ascii[max]);
return 0;
}
本帖最后由 jackz007 于 2022-8-7 19:17 编辑
【问题一】: 在计算机内,字符是通过 ASCII 编码来进行表示的,ASCII 码一共有128 个,编码范围 0 ~ 127,例如,字符 '0'、'A'、'a' 分别对应 ASCII 编码 48、65、97
在这里,ch 是字符,其实,就是一个数值为 0 ~127 的整数,很显然,字符 ch 在这里被当成了字符数组的索引了,例如,当 ch 是 '0' 时,一维数组元素 ascii[48] 的值就会被加 1。这样,当输入完成的时候,只要检查一维数组 ascii[] 内 128 个元素的数值就知道哪个字符有多少个了。
【问题二】:
统计完成后,通过循环遍历一维数组 ascii[] 内 128 个元素,通过数值比较,找到数值最大的那一个元素,其索引值对应于出现次数最多的那个字符的 ASCII 编码,元素数值为这个字符出现的次数。
|
-
题目要求
|