7-6 统计字母出现的次数 (20 分)
从键盘输入一行只有小写英文字母的字符串,用回车结束输入。统计26个英文字母出现的次数并依次输出。字符串长度不超过100个字符。
输入格式:
一行只有小写英文字母的字符串,用回车结束输入。
输出格式:
输出26行,按字典顺序输出26个小写英文字母和它们出现的次数。每个字母和它出现的次数占一行。字母和它出现的次数以一个空格隔开。
输入样例:
在这里给出一组输入。例如:
aaaaabbbcccdddeeffgghhhhijkllmnnopqrstuvwxyyyyzz
输出样例:
在这里给出相应的输出。例如:
a 5
b 3
c 3
d 3
e 2
f 2
g 2
h 4
i 1
j 1
k 1
l 2
m 1
n 2
o 1
p 1
q 1
r 1
s 1
t 1
u 1
v 1
w 1
x 1
y 4
z 2
#include<stdio.h>
void fum(char*tt,int pp[])
{
int i;
for(i=0;i<26;i++)
pp[i]=0; //pp数组全部赋0
for(i=0;tt[i];i++) //遍历tt数组
if(*(tt+i)>='a'&&*(tt+i)<='z') //tt[i]属于小写字母范围
pp[*(tt+i)-'a']++; //假如tt[i]是',a','a'-'a'=0,数组pp每个元素的初值都是
//0,pp[0]++,则pp[0]此时的元素是1,(即a个数为1),后面
//若在出现a,则pp[0]++,pp[0]就是2了
}//冰
int main()
{
char str[1000],aa[27]={'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z'};
int bb[26],k;
gets(str);
fum(str,bb);
for(k=0;k<26;k++){
printf("%c %d",aa[k],bb[k]);
if(k<25){
printf("\n");
}
}
}