题目描述
从键盘输入一行文本(小于1000字符),统计其中每个英文字母出现的频率,并输出出现过的英文字母及其次数,未出现过的不需要显示。为了简化问题的复杂度,假设在统计过程中不区分字母的大小写,即'A'与'a'被认为是一种字母。
输入要求
先从键盘输入一行文本。以换行符结束。
输出要求
输出统计结果。
输入样例
Studing C Language
输出样例
'A':2
'C':1
'D':1
'E':1
'G':3
'I':1
'L':1
'N':2
'S':1
'T':1
'U':2
#include<cstdio>
#include<cstring>
#define N 1006
int main(void)
{
char ci[N],xuhao[27];//定义一个字母表序号xuhao[27]。
int i,j,jishu=0;//字母出现频率计数器 jishu。
gets(ci);//题目说换行符结束,十有八九是用gets函数。
for(i=0;i<26;i++){
xuhao[i]='A'+i;//因为输出格式中为大写,为了方便用大写。
}
for(i=0;ci[i]!='\0';++i){//将小写字母转换成大写便于后面的判断。
if(ci[i]>='a'&&ci[i]<='z'){
ci[i]=ci[i]-('a'-'A');//由于不知道ascii码的英文大写小写之间的差值是多少,利用小写减去大写即可。
}
}
for(i=0;i<26;++i){
jishu=0;//每次判断完一个字母的频率,将计数器初始化。
for(j=0;ci[j]!='\0';j++){//gets函数默认在赋值数组末尾为换行。
if(xuhao[i]==ci[j]){
jishu++;
}
}
if(jishu!=0){
printf("'%c':%d\n",xuhao[i],jishu);//按题目要求的格式输出。
}
}
return 0;
}
|