|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
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}; //给所有的数组元素赋初值为0.
char count[NUM] = ""; //这一行是将count数组全部元素初始化为空字符,即‘\0’。为什么这样做??
printf("请输入英文文本:");
while ((ch = getchar()) != '\n')
{
ascii[ch]++; // 字符对应的ASCII码加1。 输入的字符变成了整数 再给他的索引值加1。有什么作用???
input_num++; //这是执行一次就加一么?
}
for (i = 0; i < NUM; i++) //NUM是什么?索引值么?
{
if (ascii[i]) //为什么ascii[i]=1执行下面的,这里的1是索引值还是为真,即不为\n?
{
count[j++] = i; //这里的为什么用j++??这里是将输入的每个字符给到count么?
if (ascii[i] > ascii[max]) //这里比较的是什么??
{
max = i; //这又是什么?这里的max怎么确定为是出现最多的字符的?
}
}
}
printf("你总共输入了%d个字符,其中不同的字符个数有%d个。\n", input_num, strlen(count));
printf("它们是:%s\n", count);
printf("出现次数最多的字符是\'%c\',它总共出现了%d次。\n", max, ascii[max]);
return 0;
}
1.怎么找到不同字符的?
2.怎么找到出现次数最多的字符的?
3.用索引值判断怎么个判断法?
感觉好难,麻烦大佬说详细点,我太菜了!!! |
|