|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
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[NUM] = {0};//这是什么意思 看作字典吗?
- char count[NUM] = "";
- printf("请输入英文文本:");
- while ((ch = getchar()) != '\n')
- {
- ascii[ch]++; // 字符对应的ASCII码加1
- input_num++;
- }
- for (i = 0; i < NUM; i++)//这里开始看不懂了
- {
- 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;
- }
复制代码
问题1 int ascii[NUM] = {0};什么意思 看作有序字典吗
问题2 for (i = 0; i < NUM; i++) 范围是NUM(128)为什么?这里开始的判断不懂麻烦大佬们解决一下ORZ
本帖最后由 昨非 于 2021-1-18 22:39 编辑
问题一:给所有的数组元素赋初值为0
问题二:要找到出现次数最多的字符,本质上是找到出现次数最多的字符的索引值
所以要遍历整个数组,依次比较各个字符的count值,依次找到max(最大次数对应字符的索引)
而ASCII码表中共有128个字符,这也是数组大小设为128的原因所在
|
|