题目要求如下:
根据输入的字符串中大写字母,统计其出现的次数。
主要解决思路是将字母转换为数字,再利用哈希的方式记录其出现的次数。
为了简化操作,使用1个int数组存储这26个字母的数字,其中0表示A,26表示Z。当出现对应的字母时把对应索引的值加1。这样就得到对应字母表出现的次数。
下面是实现的代码:
#include <stdio.h>
#include <string.h>
int main(){
char s[1001] = {0};
while(scanf("%s",s)!=EOF){
int numbers[26] = {0};
int length = strlen(s);
for(int i=0;i<length;i++){
char c = s[i];
if(c>='A' && c<='Z'){
numbers[c-'A'] += 1;
}
}
for(int j=0;j<26;j++){
printf("%c:%d\n",j+'A',numbers[j]);
}
}
}
下面是最终通过后的结果。