这道题也很简单,只是有一些小坑点。要一行一行的读入字符串那就得用到 getline 了。然后把那些字母全部转换成大写字母。再拿个数组统计各个字母出现的数量,最后输出。
getline用法:
getline(cin,s);
意思就是把那一行的输入放到 s 那个数组里面。
ASCII码表:
大写字母和对应的小写字母差是
32
32
32。如果你忘记的话也可以拿小写字母减大写字母。
代码:
#include<bits/stdc++.h>
using namespace std;
int n;
string s;
int a[35];//存字母出现次数的数组
int maxx = -999;
int main(){
cin >> n;
getchar();//要把第一行剩余的吞进去,否则就输入不完
for(int i = 1;i <= n;i++){
getline(cin,s);//整行输入
int len = s.size() - 1;//算它长度
for(int i = 0;i <= len;i++){
if(s[i] >= 'a' && s[i] <= 'z'){
a[int(s[i] - 'a' + 1)]++;//把他改成大写后存入数组
}else if(s[i] >= 'A' && s[i] <= 'Z'){
a[s[i] - 'A' + 1]++;
}
}
}
for(int i = 1;i <= 26;i++){
maxx = max(maxx,a[i]);//先输出最大的
}
for(int i = maxx;i >= 1;i--){
for(int j = 1;j <= 26;j++){
if(a[j] == i){
cout << char(j + 'A' - 1) << " " << a[j] << endl;//按照字母序一个一个输出
}
}
}
return 0;
}