C语言P19课后题字符统计程序求解释
2. 根据要求再写一个字符统计程序,不过这个要更复杂一些。要求 A:统计用户输入的所有字符个数;
要求 B:统计不同的字符个数,并打印出来;
要求 C:找出出现次数最多的字符
#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;
}
问题1int ascii = {0};什么意思 看作有序字典吗
问题2 for (i = 0; i < NUM; i++) 范围是NUM(128)为什么?这里开始的判断不懂麻烦大佬们解决一下ORZ
本帖最后由 昨非 于 2021-1-18 22:39 编辑
问题一:给所有的数组元素赋初值为0
问题二:要找到出现次数最多的字符,本质上是找到出现次数最多的字符的索引值
所以要遍历整个数组,依次比较各个字符的count值,依次找到max(最大次数对应字符的索引)
而ASCII码表中共有128个字符,这也是数组大小设为128的原因所在
问题1,楼上已经回答你了
问题2,因为在 ASCII 码表中,共有 128 个字符 风过无痕1989 发表于 2021-1-18 22:37
问题1,楼上已经回答你了
问题2,因为在 ASCII 码表中,共有 128 个字符
感谢{:10_254:} 昨非 发表于 2021-1-18 22:28
问题一:给所有的数组元素赋初值为0
问题二:要找到出现次数最多的字符,本质上是找到出现次数最多的字符的 ...
原来是 ”ch = getchar();ascii++;”这里不懂
现在知道了 输入的字符变成了整数 再给他的索引值加1
感谢{:10_277:}
页:
[1]