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
代码如下:
#define _CRT_SECURE_NO_WARNINGS
#pragma warning(disable:4996)
/*
解题思路:
(1)定义一个数组用来记录每个字母出现的次数,最后for循环输出
(2)每次for循环,数出共有多少个同类字符
*/
#include<stdio.h>
#include<string.h>
int main() {
char str[10000];
gets(str);
int arr[26] = { 0 };
int flag = 97;
int flag1 = 0;
int len = strlen(str);
for (int j = 0; j < 26; j++) {//第一个for循环,为26个英文字母获取每个字母出现的次数
for (int i = 0; i < len; i++) {
if (str[i] == flag) {
arr[flag1]++;
}
}
flag++;
flag1++;
}
flag = 97;
for (int i = 0; i < 26; i++) {
printf("%c %d\n", flag, arr[i]);
flag++;
}
return 0;
}