|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
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++)
{
if (ascii[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;
}
上面的代码完全看不懂啊!!!为什么count可以得出是不同字符?max得出字数最多字符?
求热心的小哥哥小姐姐指教!!!
附带注释解释
- #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码加一? 是让ascii这个数组加一,统计字符出现数量
- input_num++;
- }
- for (i = 0; i < NUM; i++)
- {
- if (ascii[i]) (问题)//这里if是什么意思?ascii[i]不是永远大于一吗,那条件不是永远成立? 这是一个数组,默认都为 0,只有字符出现了,它才会大于 0
- {
- count[j++] = i; //如果这个字符出现了,那么就把这个字符加入到count 中
- 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;
- }
复制代码
|
|